Матрицы фотоаппаратов: Матрица фотоаппарата — основа основ
Замена CCD матрицы фотоаппарата — «Golden mir»
Замена CCD матрицы фотоаппарата может потребоваться довольно неожиданно. Только вчера, казалось бы, фотоаппарат работал. А сегодня уже ни чего снять не получается и вместо изображения «квадрат малевича». Такая неисправность свойственна матрицам CCD и является следствием особенности работы матрицы. В отличие от CMOS матриц, с матрицы изготовленной по технологии CCD изображение считывается за раз целиком, а не с каждого пикселя, как у матрицы CMOS. В связи с этим при неисправностях CCD матриц вы лишаетесь изображения сразу всего целиком.
Но совершенно не стоит расстраиваться, если вас настигла такая беда. Специалисты сервисного центра Golden-mir могут выполнить замену матрицы CCD в вашем фотоаппарате в кратчайшие сроки. Сама по себе, эта операция не занимает много времени.
Для выполнения такого ремонта, естественно, необходимо фотоаппарат разобрать. В компактных фотоаппаратах, для осуществления доступа к матрице, может потребоваться демонтировать объектив, вспышку, дисплей и другие модули фотокамеры. В зеркальных фотокамерах для снятия матрицы CCD может потребоваться снять весь модуль mirror box. После замены матрицы CCD, равно как и после просто её снятия и установки на место, обязательно потребуется настройка фотоаппарата.
Выполнить замену матрицы CCD дома «на коленях» можно только при наличии необходимого инструмента и знаний. Но успех такой операции очень сомнительный. При неквалифицированной разборке фотоаппарата есть большой шанс повредить разъёмы на платах, порвать тонкие шлейфики и нарушить работу оптики камеры. Не стоит испытывать своё везение и прочность камеры. Лучше сразу обратиться в сервисный центр, где вам смогут помочь.
Контактная информация — 8 (903) 789 54 70 г. Москва ул. Сущевский вал дом 5, стр. 12, м. Савёловская, ТЦ «Савёловский», Мобильный ряд, павильон Л-173. понедельник — пятница — 10.00-20.30 суббота — воскресенье — 10.00-19.00
Кто делает сенсоры для фотоаппаратов Nikon?
Матрица (сенсор) изображения фотоаппарата Nikon D600 (фото взято на kenrockwell.com)
Не секрет, что много сенсоров для фотоаппаратов Nikon разрабатывает и производит компания Sony. Nikon попросту покупает готовые чипы-сенсоры у Sony.
Nikon также принимает участие в создании сенсоров для своих камер, но в основном компания занимается только проектированием своих собственных сенсоров, и сложно сказать, где именно их производят. Скорее всего, изготовлением\доработкой самих сенсоров занимаются\занимались компании Renesas (предположительно все сенсоры, которые начинаются на ‘NC’), Sony, Matsushita
Несколько камер выполнены на сенсорах производства Toshiba. После того, как Sony поглотила Toshiba, указывается Toshiba, а в скобочках Sony.
Также следует обязательно упомянуть, что разработка необычного сенсора JFET-LBCAST для камер Nikon D2H, D2Hs полностью принадлежит Nikon. Потому не стоит однозначно утверждать, что Nikon ничего сама не делает :).
В таблице ниже указано кто разработал\изготовил сенсор.
Внимание: данные в табличке могут не соответствовать действительности, так как очень сложно найти версию сенсора, который используется в том или ином фотоаппарате. Я попытался сделать максимально правильную\правдивую таблицу, если я где-то ошибся, пожалуйста, пишите это в комментариях и обязательно предлагайте ссылку-подтверждение.
Сенсор | Модели фотоаппаратов |
Nikon NC81338L (CMOS) | D3, D700 (сами сенсоры от Matsushita?) |
Nikon NC81361A (CMOS) | D3s (сам сенсор от Matsushita?) |
Nikon NC81362A (CMOS) | D3100 |
Nikon NC81369R (CMOS) | D3200 |
Nikon NC81366W (CMOS) | D4, D4s, Df |
Nikon JFET-LBCAST (LBCAST) | D2h, D2hs |
Sony IMX-007-AQ (CMOS) | D2x, D2xs |
Sony IMX-071 (CMOS) | D7000, D5100 |
Sony IMX-094-AQP (CMOS) | D800, D800E, D810, D810a |
Sony IMX-021-BQR (CMOS) | D300 |
Sony IMX-038-BQL (CMOS) | D90, D5000, D300s (?) |
Sony IMX-128-(L)-AQP (CMOS) | D600, D610, D750 |
Sony IMX-028 (CMOS) | D3x |
Sony ICX-453-AQ (CCD) | D40, D50, D70, D70s |
Sony ICX-493-AQA (CCD) | D40x, D60, D80, D3000 |
Sony ICX-483-AQA (CCD) | D200 |
Sony ICX-413-AQ (CCD) | D100 |
Sony IMX-193-AQK (CMOS) | D7200 (?), D5300, D5500, D5600, D3300, D3400, D3500 |
Sony (имя модели неизвестно) (CCD) | D1, D1h |
Sony (имя модели неизвестно) (особый ‘прямоугольный’ CCD) | D1x |
Toshiba HEZ1 TOS-5105 (CMOS) | D5200, D7100 |
Toshiba (Sony) T4K54 (CMOS) | D5, D6 (?) |
Sony IMX-321 (CMOS) | D500, D7500 |
Sony IMX-309-AQJ (backside illumination CMOS) | D850 (сам сенсор от Towerjazz?) |
Sony IMX-309-BQJ (backside illumination CMOS) | Nikon Z7, Z7 II (похож на IMX-309-AQJ) |
Sony | Nikon Z6, Z6 II, Z5 (похож на IMX-128) |
Хочу отметить, что сам сенсор – это основа для качественного изображения, но на аппаратном уровне есть еще много важных частей, таких как ширина ADC, возможности процессора и многое другое, которые формируют итоговое изображение.
Мой опыт
Лично мне абсолютно все равно, что там в фотоаппарате, лишь бы он хорошо работал и выполнял нужные задачи. Меня абсолютно не волнует кто, или где делаются те или иные сенсоры. Составленная мной табличка создана больше ради интереса. Но,если поразмыслить над смыслом жизни, то, конечно, хотелось бы, чтобы компания Nikon сама производила свои сенсоры, так как это сердце современного фотоаппарата, а Nikon знает смысл в качественных вещах. Да и что будет, если Sony перестанет поставлять\продавать свои сенсоры для Nikon?
Также хочу отметить, что Sony производит\продает свои сенсоры не только для Nikon, но и сама производит фотоаппараты на базе своих сенсоров, а также много фотоаппаратов Pentax (а с ним и Samsung) тоже используют сенсоры Sony.
Свои мысли на щекотливую тему сенсоров оставляйте в комментариях.
Здесь на сайте комментарии не требуют никакой регистрации. В комментариях можно задать вопрос по теме, или оставить свой отзыв, или описать свой опыт. Для подбора фототехники я рекомендую E-katalog. Много мелочей для фото можно найти на Aliexpress.
Материал подготовил Аркадий Шаповал. Мой Youtube-канал, а также группа Радоживы на Facebook и VK.
Замена и ремонт матрицы фотоаппарата в Санкт-Петербурге
Замена и ремонт матрицы фотоаппарата является на сегодняшний день одной из самых распространенных причин обращения пользователей в центр «Мастер Плюс».
Неисправность такого рода зачастую возникает из-за неосторожного обращения, некачественной заводской сборки или механического повреждения, и самым непосредственным образом влияет на процесс эксплуатации фотоаппарата и качество съемки.
Признаки того, что нужно делать замену и ремонт матрицы фотоаппарата
К основным признакам того, что необходим ремонт или замена матрицы фотоаппарата, относится появление на дисплее розовых полосок, которые хорошо заметны даже невооруженным глазом. Готовые фотографии при таком дефекте теряют свою четкость, а изображение «размывается». Зачастую розовые полоски пропадают при выключении и повторном включении фотокамеры, а также, если ее как следует встряхнуть. Однако такой «народный» способ, безусловно, может сработать раз или два, а на третий – фотоаппарат попросту откажется работать. Поэтому при появлении даже незначительных неисправностей, цифровой фотоаппарат необходимо показать специалисту и сделать замену или
Замену матрицы фотоаппарата следует доверить квалифицированным специалистам
Замена матрицы фотоаппарата – достаточно сложная процедура, сопряженная с рядом тонкостей, знаниями о которых обладают только квалифицированные специалисты Ремонтного центра «Мастер Плюс».
При появлении признаков, указывающих на наличие технической проблемы, ни в коем случае не следует пытаться сделать ремонт и замену матрицы фотоаппарата самостоятельно, руководствуясь советами, услышанными от знакомых или прочитанными в Интернете. Также не стоит доверять ремонт матрицы фотоаппарата, дисплея или, например, чистку объектива от песка неквалифицированному мастеру, обратитесь к настоящим профессионалам, т.е. в центр «Мастер Плюс»!
📷 Сервис чистки матриц фотоаппаратов
2021-03-06 12:41 в нашем сервисном центре была произведена чистка сенсора фотоаппарата 6D Mark2 по заказу 14855
. Ниже — тестовые снимки до и после чистки матрицы.Комментарий мастера сервиса: Матрица очищена
У вас тоже Canon 6D Mark2? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-06 11:21 в нашем сервисном центре была произведена чистка сенсора фотоаппарата D3200 по заказу 14856. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Nikon D3200? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-05 11:31 в нашем сервисном центре была произведена чистка сенсора фотоаппарата 1100D по заказу 14854. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Canon 1100D? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-05 18:16 в нашем сервисном центре была произведена чистка сенсора фотоаппарата 550 по заказу 14853. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Одна точка под покрытием сенсора. Все остальные загрязнения убраны
У вас тоже Canon 550? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-01 11:09 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a7 по заказу 14852. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица и объектив очищены
У вас тоже Sony a7? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-04 20:34 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a77 Mark2 по заказу 14851. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Sony a77 Mark2? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-05 13:23 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a7r по заказу 14850. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Sony a7r? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-03 22:22 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a7 3 по заказу 14849. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Sony a7 3? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-03 23:09 в нашем сервисном центре была произведена чистка сенсора фотоаппарата D750 по заказу 14848. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Nikon D750? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-04 15:51 в нашем сервисном центре была произведена чистка сенсора фотоаппарата Fujifilm X-E1 по заказу 14847. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена. Внутри объектива осталось немного пятен
У вас тоже Fujifilm X-E1? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
Матрица фотоаппарата
Матрица фотоаппарата — это микросхема с набором светочувствительных элементов (фотодиодов), предназначенная для преобразования оптического изображения в поток цифровых данных или в аналоговый электрический сигнал, которое затем обрабатывается процессором фотоаппарата и сохраняется в виде фотографии в памяти. Светочувствительные ячейки называют еще пикселями. Матрица представляет собой прямоугольную пластину из полупроводникового материала, состоящую из множества пикселей, каждый из которых при попадании на него луча света формирует электрический сигнал, размер которого зависит от интенсивности светового потока. Электрический сигнал тем больше, чем больше световой поток. Таким образом, информация о яркости света формирует черно-белую картинку.
Чтобы картинка была цветной, светочувствительные ячейки в соответствии с цветовой схемой RGB (red-green-blue) покрывают цветными светофильтрами – красным, синим или зеленым. Остальные цвета являются результатом смешения трех вышеупомянутых цветов, а также уменьшения или увеличения их насыщенности. Каждый пиксель покрывают только одним цветом. Светофильтры располагаются на матрице группами по четыре штуки таким образом, что двум зеленым соответствуют один синий и один красный. Такое соотношение объясняется тем обстоятельством, что максимальную чувствительность человеческий глаз проявляет именно к зеленому цвету. Каждый цветной фильтр пропускает в соответствующий пиксель лучи только идентичного цвета: красный пиксель — красного спектра, зеленые — зеленого, синие — синего.
Каждая матрица имеет определенные физические размеры и чем они больше, тем качество снимка лучше. По размеру матрицы можно разделить на полноформатные (Full Frame) и неполных размеров APS. Как правило, в технических характеристиках матрицы показывают не физические размеры (диагональ, площадь и ширина, в миллиметрах), а указывается количество пикселей, что является маркетинговым ходом (так как для качества изображения больше важен именно размер матрицы, а не просто количество пикселей).
К примеру, если на матрице фотоаппарата по горизонтали расположено 2592 пикселя, а по вертикали — 1944, то всего пикселей 5 038 848, то есть приблизительно 5 миллионов. В таком случае в характеристиках фотоаппарата пишут, что матрица 5 мегапикселей. Например, у профессионального зеркального фотоаппарат Canon EOS 1Ds Mark III число мегапикселей матрицы равно 22Мп, т.е. 22 миллиона пикселей, а ее размер равен 36 x 24 мм, т.е. является полноформатной (соответствует размеру 35 мм пленки).
Еще одной характеристикой матрицы является уровень цифровых шумов, которые приводят к появлению на фотографиях разноцветных крапинок, что существенно портит качество снимков и делает их нереалистичными. Одной из причин возникновения шумов может являться недостаточная освещённость, например, при ночной съемке. Избавиться от шумов можно при помощи специальных корректирующих программ, но лучше научиться правильно использовать вспышку. Шумы могут возникать также по причине низкого качества матрицы, но чаще всего из-за чрезмерного повышения фотографом светочувствительности матрицы. Светочувствительность матрицы повышают при недостаточной освещенности, когда настройка диафрагмы и выдержки не дает результата. В традиционных плёночных фотоаппаратах используется плёнка, которая уже обладает определенным ISO и поменять его нельзя, а в цифровых фотоаппаратах регулировка светочувствительности матрицы выполняется через настройки. С увеличением светочувствительности снимок будет светлее, однако уровень шумов также возрастает. Для получения качественных фотографий при съемках в условиях недостаточной освещенности, возможно, придется повышать светочувствительность, а также использовать штатив для уменьшения колебаний камеры.
Большое значение в матрице имеет также размер светочувствительных датчиков (пикселей). Чем больше размер пикселей, тем выше светопередача и ниже уровень шумов. Другими словами, на матрице с большими пикселями получается более качественное изображение. Поэтому даже если два фотоаппарата имеют одинаковое количество пикселей, но у первого размер самих пикселей больше чем у второго (соответственно и размер матрицы первого будет больше), то первый фотоаппарат выдаст более высокое качество снимка, чем второй. Вполне естественно, что смартфоны и мобильные телефоны оборудованы матрицами с самыми скромными размерами, так как место под камеру в таких устройствах очень ограничено. Совсем немного за счёт размера матрицы выигрывают у смартфонов цифровые мыльницы. Профессиональные зеркальные камеры комплектуются большими матрицами (36 х 24 мм, как у светочувствительной 35 мм плёнки) с большими светочувствительными датчиками (пикселями). К сожалению, многие покупатели становятся заложниками маркетинговых ухищрений и не обращают внимания на геометрические размеры матрицы и пикселя, а покупают устройства, ориентируясь исключительно на количество пикселей. Хотя, уровень качества фотоснимков во многом определяется именно физическими размерами матрицы, а от количества пикселей больше зависит максимальная величина снимка.
Автор: FC,
23.05.2013 г.
📷 Сервис чистки матриц фотоаппаратов
2021-03-06 12:41 в нашем сервисном центре была произведена чистка сенсора фотоаппарата 6D Mark2 по заказу 14855. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Canon 6D Mark2? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-06 11:21 в нашем сервисном центре была произведена чистка сенсора фотоаппарата D3200 по заказу 14856. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Nikon D3200? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-05 11:31 в нашем сервисном центре была произведена чистка сенсора фотоаппарата 1100D по заказу 14854. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Canon 1100D? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-05 18:16 в нашем сервисном центре была произведена чистка сенсора фотоаппарата 550 по заказу 14853. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Одна точка под покрытием сенсора. Все остальные загрязнения убраны
У вас тоже Canon 550? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-01 11:09 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a7 по заказу 14852. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица и объектив очищены
У вас тоже Sony a7? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-04 20:34 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a77 Mark2 по заказу 14851. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Sony a77 Mark2? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-05 13:23 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a7r по заказу 14850. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Sony a7r? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-03 22:22 в нашем сервисном центре была произведена чистка сенсора фотоаппарата a7 3 по заказу 14849. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Sony a7 3? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-03 23:09 в нашем сервисном центре была произведена чистка сенсора фотоаппарата D750 по заказу 14848. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена
У вас тоже Nikon D750? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
2021-03-04 15:51 в нашем сервисном центре была произведена чистка сенсора фотоаппарата Fujifilm X-E1 по заказу 14847. Ниже — тестовые снимки до и после чистки матрицы.
Комментарий мастера сервиса: Матрица очищена. Внутри объектива осталось немного пятен
У вас тоже Fujifilm X-E1? Ждём вас на профессиональную чистку матрицы!
Телефон:+7 (499) 346-84-46
Адрес: м.Красные ворота, м.Комсомольская, Каланчевская улица, дом 17 с.1, 6-ой этаж
Рассекая матрицу камеры, Часть 3: Внутренняя матрица ←
13 августа 2013 г.
Сегодня мы изучим внутреннюю матрицу камеры в нашей третьей и последней главе трилогии «Рассечение матрицы камеры». В первой статье мы узнали, как разделить полную матрицу камеры на внутреннюю и внешнюю матрицы и как правильно обрабатывать неоднозначности, возникающие в этом процессе. Во второй статье внешняя матрица была рассмотрена более подробно, рассмотрены несколько различных интерпретаций ее трехмерных вращений и перемещений.Сегодня мы так же рассмотрим внутреннюю матрицу, исследуя две эквивалентные интерпретации: как описание геометрии виртуальной камеры и как последовательность простых 2D-преобразований. После этого вы увидите интерактивную демонстрацию, иллюстрирующую обе интерпретации.
Если вам не интересно углубляться в теорию и вы просто хотите использовать свою внутреннюю матрицу с OpenGL, ознакомьтесь со статьями «Калиброванные камеры в OpenGL без glFrustum», «Калиброванные камеры» и «gluPerspective».
Все эти статьи являются частью серии «Камера перспективы, интерактивный тур». Чтобы прочитать другие статьи этой серии, перейдите к оглавлению.
Внутренняя матрица преобразует координаты трехмерной камеры в двумерные координаты однородного изображения. Эта перспективная проекция моделируется идеальной камерой-обскурой, показанной ниже.
Внутренняя матрица параметризована Хартли и Зиссерманом как
\ [ K = \ left ( \ begin {array} {c c c} f_x & s & x_0 \\ 0 & f_y & y_0 \\ 0 & 0 & 1 \\ \ end {массив} \верно ) \]
Каждый внутренний параметр описывает геометрическое свойство камеры.Давайте подробно рассмотрим каждое из этих свойств.
Фокусное расстояние, \ (f_x \), \ (f_y \)
Фокусное расстояние — это расстояние между отверстием и пленкой (или плоскостью изображения). По причинам, которые мы обсудим позже, фокусное расстояние измеряется в пикселях. В настоящей камере-обскуре и \ (f_x \), и \ (f_y \) имеют одинаковое значение, которое показано как \ (f \) ниже.
На практике \ (f_x \) и \ (f_y \) могут различаться по ряду причин:
- Дефекты сенсора цифровой камеры.
- Изображение было неравномерно масштабировано при постобработке.
- Объектив камеры создает непреднамеренное искажение.
- В камере используется анаморфный формат, в котором объектив сжимает широкоэкранную сцену в матрицу стандартного размера.
- Ошибки калибровки камеры.
Во всех этих случаях результирующее изображение имеет неквадратные пиксели.
Наличие двух разных фокусных расстояний не очень интуитивно понятно, поэтому в некоторых текстах (например, Форсайт и Понсе) используется одно фокусное расстояние и «соотношение сторон», которое описывает величину отклонения от идеально квадратного пикселя.Такая параметризация хорошо отделяет геометрию камеры (то есть фокусное расстояние) от искажения (соотношения сторон).
Смещение главной точки, \ (x_0 \), \ (y_0 \)
«Главная ось» камеры — это линия, перпендикулярная плоскости изображения, которая проходит через точечное отверстие. Его пересечение с плоскостью изображения называется «главной точкой», как показано ниже.
«Смещение главной точки» — это положение главной точки относительно исходной точки пленки.Точное определение зависит от того, какое соглашение используется для определения местоположения происхождения; на иллюстрации ниже предполагается, что он находится в нижнем левом углу фильма.
Увеличение \ (x_0 \) смещает точечное отверстие вправо:
Это эквивалентно смещению пленки влево и оставлению точечного отверстия без изменений.
Обратите внимание, что рамка, окружающая камеру, не имеет значения, имеет значение только положение точечного отверстия относительно пленки.
Наклон оси, \ (s \)
Наклон оси вызывает сдвиговое искажение проецируемого изображения. Насколько мне известно, нет никакого аналога смещению оси для настоящей камеры-обскуры, но очевидно, что некоторые процессы оцифровки могут вызвать ненулевой перекос. Мы рассмотрим перекос подробнее позже.
Прочие геометрические свойства
Фокусное расстояние и смещение главной точки представляют собой простые перемещения пленки относительно точечного отверстия. Должны же быть другие способы трансформировать камеру, верно? А как насчет поворота или масштабирования пленки?
Вращение пленки вокруг точечного отверстия эквивалентно вращению самой камеры, которым управляет внешняя матрица.Вращение пленки вокруг любой другой фиксированной точки \ (x \) эквивалентно вращению вокруг отверстия \ (P \) с последующим перемещением на \ ((x-P) \).
А как насчет масштабирования? Должно быть очевидно, что удвоение всех размеров камеры (размера пленки и фокусного расстояния) не влияет на снимаемую сцену. Если вместо этого вы удвоите размер пленки и фокусное расстояние , а не , это будет эквивалентно удвоению обоих (без операции) и последующему уменьшению фокусного расстояния вдвое. Таким образом, явное представление масштаба фильма было бы излишним; он фиксируется фокусным расстоянием.
Фокусное расстояние — от пикселей до мировых единиц
Это обсуждение масштабирования камеры показывает, что существует бесконечное количество камер-обскур, которые производят одно и то же изображение. Внутренняя матрица касается только отношения между координатами камеры и координатами изображения, поэтому абсолютные размеры камеры не имеют значения. Использование пиксельных единиц для фокусного расстояния и смещения главной точки позволяет нам представить относительные размеры камеры, а именно положение пленки относительно ее размера в пикселях.
Другими словами, внутреннее преобразование камеры инвариантно к равномерному масштабированию геометрии камеры. Представляя размеры в пикселях, мы естественным образом фиксируем эту неизменность.
Вы можете использовать аналогичные треугольники для преобразования пиксельных единиц в мировые единицы (например, мм), если вы знаете хотя бы одно измерение камеры в мировых единицах. Например, если вы знаете, что пленка камеры (или цифровой датчик) имеет ширину \ (W \) в миллиметрах, а ширина изображения в пикселях равна \ (w \), вы можете преобразовать фокусное расстояние \ (f_x \) в мировых единиц, использующих:
\ [F_x = f_x \ frac {W} {w} \]
Другие параметры \ (f_y \), \ (x_0 \) и \ (y_0 \) могут быть преобразованы в их аналоги в мировых единицах \ (F_y \), \ (X_0 \) и \ (Y_0 \), используя аналогичные уравнения:
\ [ \ begin {array} {ccc} F_y = f_y \ frac {H} {h} \ qquad X_0 = x_0 \ frac {W} {w} \ qquad Y_0 = y_0 \ frac {H} {h} \ end {массив} \]
Как мы обсуждали ранее, только расположение отверстия и материала пленки, поэтому физическая коробка, окружающая камеру, не имеет значения.По этой причине во многих обсуждениях геометрии камеры используется более простое визуальное представление: пирамида камеры.
Область обзора камеры имеет форму пирамиды, которую иногда называют «конусом видимости». Давайте добавим к нашей сцене несколько трехмерных сфер и покажем, как они попадают в конус видимости, и создадим изображение.
Так как «коробочка» камеры не имеет значения, снимем ее. Также обратите внимание, что изображение в фильме представляет собой зеркальную версию реальности. Чтобы исправить это, мы будем использовать «виртуальный образ» вместо самого фильма.Виртуальное изображение имеет те же свойства, что и изображение на пленке, но в отличие от настоящего изображения виртуальное изображение появляется перед камерой, а проецируемое изображение не переворачивается.
Обратите внимание, что положение и размер плоскости виртуального изображения произвольны — мы могли бы удвоить ее размер, если бы мы также удвоили расстояние от отверстия.
После удаления истинного изображения мы остаемся с представлением «усеченной пирамиды» нашей камеры-обскуры.
Точечное отверстие было заменено кончиком конуса видимости, и пленка теперь представлена виртуальной плоскостью изображения.Позже мы будем использовать это представление для нашей демонстрации.
В предыдущих разделах мы интерпретировали наши входящие 3-вектора как координаты трехмерного изображения, которые преобразуются в координаты однородного двухмерного изображения. В качестве альтернативы мы можем интерпретировать эти 3-вектора как однородные 2D-координаты, которые преобразуются в новый набор 2D-точек. Это дает нам новый взгляд на внутреннюю матрицу: последовательность двумерных аффинных преобразований.
Мы можем разложить внутреннюю матрицу на последовательность преобразований сдвига, масштабирования и смещения, соответствующих перекосу оси, фокусному расстоянию и смещению главной точки, соответственно:
\ [ \ begin {align} K & = \ left ( \ begin {array} {c c c} f_x & s & x_0 \\ 0 & f_y & y_0 \\ 0 & 0 & 1 \\ \ end {массив} \верно ) \\ [0.5em] знак равно \ underbrace { \оставили ( \ begin {array} {c c c} 1 & 0 & x_0 \\ 0 & 1 & y_0 \\ 0 и 0 и 1 \ end {массив} \верно ) } _ \ text {2D-перевод} \ раз \ underbrace { \оставили ( \ begin {array} {c c c} f_x & 0 & 0 \\ 0 & f_y & 0 \\ 0 и 0 и 1 \ end {массив} \верно ) } _ \ text {2D-масштабирование} \ раз \ underbrace { \оставили ( \ begin {array} {c c c} 1 & s / f_x & 0 \\ 0 & 1 & 0 \\ 0 и 0 и 1 \ end {массив} \верно ) } _ \ text {2D сдвиг} \ end {align} \]
Эквивалентное разложение помещает сдвиг после масштабирования :
\ [ \ begin {align} K & = \ underbrace { \оставили ( \ begin {array} {c c c} 1 & 0 & x_0 \\ 0 & 1 & y_0 \\ 0 и 0 и 1 \ end {массив} \верно ) } _ \ text {2D-перевод} \ раз \ underbrace { \оставили ( \ begin {array} {c c c} 1 & s / f_y & 0 \\ 0 & 1 & 0 \\ 0 и 0 и 1 \ end {массив} \верно ) } _ \ text {2D сдвиг} \ раз \ underbrace { \оставили ( \ begin {array} {c c c} f_x & 0 & 0 \\ 0 & f_y & 0 \\ 0 и 0 и 1 \ end {массив} \верно ) } _ \ text {2D-масштабирование} \ end {align} \]
Эта интерпретация прекрасно разделяет внешние и внутренние параметры на области 3D и 2D, соответственно.Также подчеркивается, что внутреннее преобразование камеры происходит после проекции . Одним из примечательных результатов этого является то, что внутренние параметры не могут влиять на видимость. — закрытые объекты не могут быть обнаружены простыми двухмерными преобразованиями в пространстве изображения.
Демо ниже иллюстрирует обе интерпретации внутренней матрицы. Слева — интерпретация «геометрии камеры». Обратите внимание, как точечное отверстие перемещается относительно плоскости изображения при настройке \ (x_0 \) и \ (y_0 \).
Справа — интерпретация «2D-трансформации». Обратите внимание, как изменение результатов фокусного расстояния приводит к масштабированию проецируемого изображения, а изменение главной точки приводит к чистому преобразованию.
Для этой демонстрации требуетсяJavascript.
Слева : сцена с камерой и просмотром. Виртуальная плоскость изображения отображается желтым цветом. Справа : изображение камеры.
В ходе этой серии статей мы увидели, как разложить
- полная матрица камеры на внутреннюю и внешнюю матрицы,
- внешняя матрица в трехмерное вращение с последующим переносом, а
- внутреннюю матрицу на три основных 2D преобразования.\ text {Внешняя матрица} \\ [0.5em]
знак равно
\ overbrace { \ underbrace {
\оставили (
\ begin {array} {c c c}
1 & 0 & x_0 \\
0 & 1 & y_0 \\
0 и 0 и 1
\ end {массив}
\верно )
} _ \ text {2D-перевод} \ раз \ underbrace {
\оставили (
\ begin {array} {c c c}
f_x & 0 & 0 \\
0 & f_y & 0 \\
0 и 0 и 1
\ end {массив}
\верно )
} _ \ text {2D-масштабирование} \ раз \ underbrace {
\оставили (
\ begin {array} {c c c}
1 & s / f_x & 0 \\
0 & 1 & 0 \\
0 и 0 и 1
\ end {массив}
\верно )
} _ \ text {2D сдвиг} } ^ \ text {Внутренняя матрица} \ раз \ overbrace {
\ underbrace {
\ left (\ begin {array} {c | c}
Я & \ mathbf {t}
\ end {array} \ right)
} _ \ text {3D-перевод}
\ раз
\ underbrace {
\ left (\ begin {array} {c | c}
R & 0 \\ \ hline
0 и 1
\ end {array} \ right)
} _ \ text {3D-вращение}
} ^ \ text {Внешняя матрица}
\ end {align}
\]
Чтобы увидеть все эти преобразования в действии, перейдите на мою страницу «Игрушка с перспективной камерой», где представлена интерактивная демонстрация камеры с полной перспективой.
Есть ли у вас другие способы интерпретации внутренней матрицы камеры? Оставьте комментарий или напишите мне!
В следующий раз мы покажем, как подготовить откалиброванную камеру для создания пар стереоизображений. Увидимся позже!
Сообщение от Кайл Симек Пожалуйста, включите JavaScript, чтобы просматривать комментарии от Disqus. комментарии в блоге, разработанныеСамокалибровка движущейся камеры по точечным соответствиям и фундаментальным матрицам
Ayache, N.1990. Stereovision and Sensor Fusion . MIT Press.
Басу, А. 1993. Активная калибровка: альтернативная стратегия и анализ. В Proc . конф. . по компьютерному зрению и распознаванию образов , Нью-Йорк, стр. 495–500.
Бранд, П., Мор, Р., и Бобет, П., 1993. Оптические искажения: коррекция в моделировании. Технический отчет RR-1933, INRIA.
Кокстер, Х. С. М. 1987. Проективная геометрия .SpringerVerlag, второе издание.
Кроули Дж., Бобет П. и Шмид К. 1993. Поддержание стереокалибровки путем отслеживания точек изображения. В Proc . конф. . по компьютерному зрению и распознаванию образов , Нью-Йорк, стр. 483–488.
Дериче Р. и Блашка Т. 1993. Восстановление и определение характеристик изображения с использованием эффективного подхода, основанного на модели. В Proc . Международная конференция по компьютерному зрению и распознаванию образов .
Дериш Р., Вайян Р. и Фогерас О. 1992. От точек зашумленных краев к трехмерной реконструкции сцены: надежный подход и его анализ неопределенности , Vol. 2. С. 71–79. World Scientific. Серия по машинному восприятию и искусственному интеллекту.
Google ученый
Дрон, Л. 1993. Динамическая самокалибровка камеры по управляемым последовательностям движения. В Proc . конф. . по компьютерному зрению и распознаванию образов , Нью-Йорк, стр. 501–506.
Ду Ф. и Брэди М. 1993. Самокалибровка внутренних параметров камер для систем активного зрения. В Proc . конф. . по компьютерному зрению и распознаванию образов , Нью-Йорк, стр. 477–482.
Фанг, Дж. К. и Хуанг, Т. С. 1984. Некоторые эксперименты по оценке параметров трехмерного движения твердого тела из двух последовательных кадров изображения. Транзакции IEEE по анализу шаблонов и машинному анализу , 6: 545–554.
Google ученый
Фогерас О. Д. 1993. Трехмерное компьютерное зрение: геометрическая точка зрения . MIT Press.
Фаугерас О. Д. и Тоскани Г. 1986. Проблема калибровки стерео. В Труды ЦВПР’86 , стр. 15–20.
Фогерас, О. Д., Люстман, Ф., и Тоскани, Г.1987. Движение и структура по точкам и линиям. В Proc . Международная конференция по компьютерному зрению , стр. 25–34.
Фаугерас, О. Д. и Мэйбанк, С. Дж. 1990. Движение из точек совпадений: множественность решений. Международный журнал компьютерного зрения , 4 (3): 225–246, также INRIA Tech. Отчет 1157.
Google ученый
Faugeras, O.D., Luong, Q.-T., and Maybank, S.J. 1992. Самокалибровка камеры: теория и эксперименты. В Proc . Европейская конференция по компьютерному зрению , Санта-Маргерита, Италия, стр. 321–334.
Гарнер Л. Э. 1981. Схема проективной геометрии . Эльзевир: Северная Голландия.
Google ученый
Голуб, Г. Х. и Ван Лоан, К. Ф. 1989. Матричные вычисления . Издательство Университета Джона Хопкинса.
Хартли, Р.I. 1992. Оценка относительного положения камеры для некалиброванных камер. В Proc . Европейская конференция по компьютерному зрению , стр. 579–587.
Хартли Р. И. 1994a. Алгоритм самокалибровки с нескольких точек зрения. В Proc . Конференция по компьютерному зрению и распознаванию образов , Сиэтл, Вашингтон, стр. 908–912.
Хартли Р. И. 1994b. Самокалибровка из нескольких изображений с вращающейся камерой. В Proc . Европейская конференция по компьютерному зрению , Стокгольм, Швеция, стр. 471–478.
Хорн, Б. К. П. 1990. Относительная ориентация. Международный журнал компьютерного зрения , 4 (1): 59–78.
Google ученый
Хуанг, Т. С. и Фагерас, О. Д. 1989. Некоторые свойства Ematrix при оценке движения в двух представлениях. Транзакции IEEE по анализу шаблонов и машинному анализу , 11: 1310–1312.
Google ученый
Язвински А. М. 1970. Стохастические процессы и теория фильтрации . Академическая пресса: Лондон.
Google ученый
Канатани К. 1991. Вычислительная проективная геометрия. Компьютерное зрение, графика и обработка изображений . Понимание изображений , 54 (3).
Канатани К. 1992. Геометрические вычисления для машинного зрения .Издательство Оксфордского университета.
Kruppa, E. 1913. Zur Ermittlung eines Objektes aus zwei Perspektiven mit innerer Orientierung. Sitz . -Ber . Акад . Висс . , Вена, математика . naturw . Kl . , Abt . IIa ., 122: 1939–1948.
Google ученый
Кумар Р. и Хэнсон А. 1990. Чувствительность проблемы уточнения позы к точной оценке параметров камеры.In Proceedings of the International Conference on Computer Vision , Osaka, Japan, pp. 365–369.
Кумар Р. В., Тирумалай А. и Джайн Р. К. 1989. Нелинейный алгоритм оптимизации для оценки параметров конструкции и движения. В Proc . Международная конференция по компьютерному зрению и распознаванию образов , стр. 136–143.
Лонге-Хиггинс, Х. С. 1981. Компьютерный алгоритм для восстановления сцены из двух проекций. Nature , 293: 133–135.
Google ученый
Luong, Q.-T. 1992. Matrice fondamentale et auto-calibration en vision par ordinateur. Кандидатская диссертация, Universite de Paris-Sud, Орсе.
Google ученый
Luong, Q.-T. и Фогерас, О. Д. 1992. Самокалибровка камеры с использованием множественных изображений. В Proc . Международная конференция по распознаванию образов , Den Hag, Нидерланды, стр.9–12.
Luong, Q.-T. и Viéville, T. 1996. Канонические представления геометрии множественных проективных представлений. Компьютерное зрение и понимание изображений , 64 (2): 193–229.
Google ученый
Luong, Q.-T. и Фаугерас, О. Д. 1994. Структура оптимизации для эффективной самокалибровки и определения движения. В Proc . Международная конференция по распознаванию образов , Иерусалим, Израиль, стр.А-248 – А-252.
Luong, Q.-T. и Фогерас, О. Д. 1994. Анализ устойчивости фундаментальной матрицы. В Proc . Европейская конференция по компьютерному зрению , Стокгольм, Швеция, стр. 577–588.
Luong, Q.-T. и Фогерас, О. Д. 1996. Фундаментальная матрица: теория, алгоритмы и анализ устойчивости. Международный . Журнал компьютерного зрения 7 (1): 43–76.
Google ученый
Luong, Q.-Т., Дериш, Р., Фаугерас, О. Д., и Пападопуло, Т. 1993. Об определении фундаментальной матрицы: анализ различных методов и экспериментальных результатов. Технический отчет RR-1894, INRIA
Maybank, S. J. 1990. Проективная геометрия неоднозначных поверхностей. Proc . Лондонского королевского общества A , 332: 1–47.
Google ученый
Мэйбанк, С. Дж. И Фогерас, О. Д. 1992. Теория самокалибровки движущейся камеры. Международный журнал компьютерного зрения , 8 (2): 123–151.
Google ученый
Maybeck, P. S. 1979. Стохастические модели, оценка и управление . Академическая пресса: Лондон.
Google ученый
Манди Дж. Л. и Зиссерман А. (ред.) 1992. Геометрическая инвариантность в компьютерном зрении . MIT Press.
Роберт Л.1993. Реконструкция курбов и поверхностей par Vision stéréoscopique. Приложения a la robotique mobile. Кандидатская диссертация, Политехническая школа.
Семпл, Дж. Г. и Колено, Г. Т. 1979. Алгебраическая проективная геометрия . Clarendon Press: Oxford, 1952 (перепечатано).
Google ученый
Спецакис, М. Э. и Алоимонос, Дж. 1988. Оптимальное вычисление конструкции на основе движения с использованием точечных соответствий в двух кадрах.В Proc . Международная конференция по компьютерному зрению , стр. 449–453.
Триведи, Х. П. 1988. Может ли несколько видов компенсировать отсутствие регистрации камеры? Image and Vision Computing , 6 (1): 29–32.
Google ученый
Цай, Р. Ю. 1989. Краткий обзор последних достижений в калибровке камеры для трехмерного машинного зрения. У Усама Хатиба, Джона Дж. Крейга и Томаса Лосано-Переса (ред.), Обзор робототехники . MIT Press: стр. 147–159.
Цай Р. Ю. и Хуанг Т. С. 1984. Уникальность и оценка параметров трехмерного движения твердых объектов по криволинейным поверхностям. Транзакции IEEE по анализу шаблонов и машинному интеллекту , 6: 13–27.
Google ученый
Ульман С. 1979. Интерпретация визуального движения . MIT Press.
Вивиль, Т.1994. Автокалибровка параметров визуального датчика на голове робота. Image and Vision Computing , 12.
Wampler, C. W., Morgan, A. P., и Sommese, A. J. 1988. Методы численного продолжения для решения полиномиальных систем, возникающих в кинематике. Технический отчет GMR-6372, Исследовательская лаборатория General Motors.
Вен, Дж., Ахуджа, Н. и Хуанг, Т. С. 1989. Оптимальное движение и оценка конструкции. В Proc . Международная конференция по компьютерному зрению и распознаванию образов , стр.144–152.
Чжан З. и Фогерас О. Д. 1992. Анализ динамической трехмерной сцены . Springer-Verlag.
Zhang, Z., Deriche, R., Faugeras, O., and Luong, Q.-T. 1995. Надежный метод сопоставления двух некалиброванных изображений посредством восстановления неизвестной эпиполярной геометрии. Журнал искусственного интеллекта 78: 87–119.
Google ученый
- Поэкспериментируйте с этими значениями,чтобы увидеть,как они влияют на то,что отображается на экране.Обратите внимание,как ранее обрезанный синий прямоугольник возвращается в диапазон,задав его компонент w.
- Попробуйте создать новый блок,который находится за пределами пространства клипа,и верните его,разделив на w.
- Уменьшите прямоугольник с помощью масштабной матрицы и разместите его в разных местах в пространстве клипа.
- Попробуйте переместить его за пределы области клипа.
- Измените размер окна и посмотрите,как прямоугольник теряет форму.
- Добавьте матрицу
rotateZ
. fieldOfviewInRadians
- Угол в радианах,указывающий,какая часть сцены видна зрителю одновременно.Чем больше число,тем больше видно для камеры.Геометрия по краям становится все более и более искаженной,как у широкоугольного объектива.Когда поле зрения больше,объекты обычно становятся меньше.Когда поле зрения меньше,камера может видеть все меньше и меньше в сцене.Объекты намного меньше искажаются перспективой,и объекты кажутся намного ближе к камере
Соотношение сторон
- Соотношение сторон сцены,эквивалентное ширине,деленной на высоту.В этих примерах ширина окна делится на высоту окна.Введение этого параметра окончательно решает проблему,при которой модель деформируется при изменении размера и формы холста.
Ближайшее расстояние полета
- Положительное число,обозначающее расстояние от экрана до плоскости,перпендикулярной полу,ближе к которой все отсекается.Он отображается в-1 в пространстве клипа и не должен быть установлен в 0.
farClippingPlaneDistance
- Положительное число,указывающее расстояние до плоскости,за пределами которой геометрия отсекается.Это отображается в 1 в пространстве клипа.Это значение должно быть достаточно близко к расстоянию до геометрии,чтобы избежать ошибок точности,возникающих при рендеринге.
- Поэкспериментируйте с параметрами матрицы перспективной проекции и матрицы модели.
- Поменяйте местами матрицу перспективной проекции,чтобы использовать ортогональную проекцию.В общем коде MDN WebGL вы найдете
MDN.orthographicMatrix()
.Это может заменить функциюMDN.perspectiveMatrix()
вCubeDemo.prototype.computePerspectiveMatrix()
.
Внутренняя матрица обратной камеры для плоскости изображения при Z = -1
Подобный вопрос задавался ранее, к сожалению, я не могу комментировать ответ Samgaks, поэтому я открываю новый пост с этим.Вот ссылка на старый вопрос:
Как рассчитать луч в реальной системе координат из изображения с помощью матрицы проекции?
Моя цель — преобразовать координаты изображения в мировые координаты. Фактически я пытаюсь сделать это с помощью внутренних параметров камеры HoloLens Camera. -1 * Ppix;
Pcam_x = P_pix_x / fx — cx / fx;
Pcam_y = P_pix_y / fy — cy / fy;
Pcam_z = 1
Ориентация системы координат камеры и плоскости изображения
В этом конкретном случае плоскость изображения, вероятно, находится на Z = -1 (однако я немного не уверен в этом).-1 перевернуты s.t. вычисляем координаты следующим образом:
Pcam_x = (Ppix_x / fx) — (cx * (- 1) / fx) = P_pix_x / fx + cx / fx;
Pcam_y = (Ppix_y / fy) — (cy * (- 1) / fy) = P_pix_y / fy + cy / fy;
Pcam_z = -1
Pcam = (Pcam_x, Pcam_y, -1)
CameraOpticalCentre = (0,0,0)
Луч = Pcam — CameraOpticalCentre
Я не понимаю, как создать внутреннюю функцию камеры для случая, когда плоскость изображения имеет отрицательную Z-координату.И я хотел бы получить математическое объяснение или интуитивное понимание того, почему у нас есть переворот знака (P_pix_x / fx + cx / fx вместо P_pix_x / fx — cx / fx).
Edit: я читал в другом посте, что столбец жажды матрицы камеры должен быть инвертирован в случае, если камера направлена вниз в отрицательном направлении по оси Z. Это объяснило бы переворот знака. Однако зачем нам менять знак третьего столбца. Хотелось бы иметь интуитивное понимание этого. Вот ссылка на пост Отрицание третьего столбца
Заранее большое спасибо, Лиза
Урок 1 Часть 2: Проективная геометрия камеры — Модуль 1: Основы трехмерного компьютерного зрения
В этом видео вы узнаете, как смоделировать проективную геометрию камеры посредством преобразования системы координат.Эти преобразования можно использовать для проецирования точек из мирового кадра в кадр изображения, основываясь на модели камеры-обскуры из предыдущего видео. Напомним, что вы уже широко использовали преобразования в курсе 2. Затем вы смоделируете эти преобразования с помощью матричной алгебры и примените их к трехмерной точке, чтобы получить ее двухмерную проекцию на плоскость изображения. Наконец, вы узнаете, как 2D-изображения камеры представлены в программном обеспечении. Используя уравнения проекции в определениях изображений, вы сможете создавать алгоритмы для обнаружения объектов в 3D и локализации беспилотного автомобиля позже в ходе курса.Во-первых, давайте определим проблему, которую нам нужно решить. Начнем с точки O мира, определенной в определенном месте в мировой системе координат. Мы хотим спроецировать эту точку из кадра мира на плоскость изображения камеры. Свет распространяется от мира O на объекте через апертуру камеры к поверхности сенсора. Вы можете видеть, что наша проекция на поверхность сенсора через апертуру приводит к перевернутым изображениям объектов в мире. Чтобы избежать этой путаницы, мы обычно определяем виртуальную плоскость изображения перед центром камеры.Давайте перерисуем нашу модель камеры с помощью этой плоскости сенсора вместо плоскости реального изображения за объективом камеры. Мы будем называть эту модель упрощенной моделью камеры, и нам необходимо разработать модель того, как проецировать точку из координат x, y и z мировой рамки в координаты u и v изображения. Начнем с определения следующих характеристик камер которые имеют отношение к нашей проблеме. Сначала мы выбираем мировую рамку, в которой определяем координаты всех объектов и камеры. Мы также определяем координатную рамку камеры как координатную рамку, прикрепленную к центру апертуры нашего объектива, известную как оптический датчик.Как мы узнали из курса 2, мы можем определить вектор переноса и матрицу вращения для моделирования любого преобразования между одним мировым координатным кадром и другим, и в этом случае мы будем использовать мировой координатный кадр и координатный кадр камеры. Мы называем параметры положения камеры внешними параметрами, поскольку они являются внешними по отношению к камере и зависят от местоположения камеры в мировой системе координат. Мы определяем нашу систему координат изображения как систему координат, прикрепленную к нашей виртуальной плоскости изображения, исходящей из оптического центра.Однако система координат пикселей изображения прикрепляется к верхнему левому углу плоскости виртуального изображения. Поэтому нам нужно настроить расположение пикселей в соответствии с рамкой координат изображения. Затем мы определяем фокусное расстояние — это расстояние между камерой и кадрами координат изображения по оси z кадра координат камеры. Наконец, наша проблема проекции сводится к двум шагам. Сначала нам нужно проецировать из мира в координаты камеры, затем мы проецируем из координат камеры в координаты изображения.Затем мы можем преобразовать координаты изображения в пиксельные координаты с помощью масштабирования и смещения. Теперь у нас есть геометрическая модель, позволяющая проецировать точку из этого мирового фрейма в координатный фрейм изображения, когда мы захотим. Сформулируем математические инструменты, необходимые для выполнения этой проекции, с помощью линейной алгебры. Во-первых, мы начинаем с преобразования мира в систему координат камеры. Это выполняется с помощью матрицы преобразования твердого тела T, в которой есть R и немного t.Следующим шагом является преобразование координат камеры в координаты изображения. Чтобы выполнить это преобразование, мы определяем матрицу K как матрицу размером три на три. Эта матрица зависит от внутренних параметров камеры, что означает, что она зависит от внутренних компонентов камеры, таких как геометрия камеры и характеристики объектива камеры. Поскольку оба преобразования представляют собой просто умножение матриц, мы можем определить матрицу P как K, умноженную на R и t, которая преобразуется из мировой системы координат до кадра координат изображения.Координаты точки O в мировом фрейме теперь могут быть спроецированы на плоскость изображения с помощью уравнения O суб-изображения равно P умножить на O суб-мира, что в k раз R и t суб-мира O. Итак, давайте посмотрим, чего нам еще не хватает для вычисления этого уравнения. Когда мы ожидали размерности матрицы, мы заметили, что умножение матрицы не может быть выполнено. Чтобы решить эту проблему, мы преобразуем координаты точки O в однородные координаты, и это делается путем добавления единицы в конце трехмерных координат, как мы видели во втором курсе оценки состояния.Итак, теперь размеры работают, и мы все готовы приступить к расчету наших прогнозов. Теперь нам нужно выполнить последний шаг, преобразовав координаты изображения в пиксельные координаты. Мы делаем это путем деления x и y на z, чтобы получить однородные координаты в плоскости изображения. Вы завершили базовую проекционную модель камеры. На практике мы обычно моделируем более сложные явления, такие как неквадратные пиксели, перекос при доступе к камере, искажение и нестандартное соотношение сторон. К счастью, это изменяет только K-матрицу камеры, и выученные вами уравнения можно использовать как есть с несколькими дополнительными параметрами.Теперь, когда мы сформулировали координаты проекции 3D-точки на плоскость 2D-изображения, мы хотим определить, какие значения входят в координаты в цветном 2D-изображении. Начнем с изображения в оттенках серого. Сначала мы определяем ширину N и высоту M изображения как количество строк и столбцов в изображении. Каждая точка в 3D проецируется на пиксель изображения, определяемый полученными ранее координатами uv. Увеличив масштаб, мы видим, что эти пиксели представляют собой сетку. В градациях серого информация о яркости записывается в каждом пикселе как восьмибитовое целое число без знака.Некоторые камеры могут создавать беззнаковые 16-битные целые числа для лучшего качества изображений. Для цветных изображений у нас есть третье измерение со значением три, которое мы называем глубиной. Каждый канал этой глубины показывает, сколько определенного цвета присутствует в изображении. Доступны многие другие цветовые представления, но на протяжении всего курса мы будем использовать представление RGB, например красный, зеленый, синий. В заключение, изображение представляется в цифровом виде как M на N с помощью трех массивов пикселей, причем каждый пиксель представляет собой проекцию трехмерной точки на плоскость двухмерного изображения.Итак, в этом видео вы узнали, как проецировать трехмерные точки в кадре мировых координат на 2D-точки в кадре координат изображения. Вы видели, что уравнения, которые выполняют эту проекцию, зависят от внутренних параметров камеры, а также от положения камеры в мировой системе координат. Как мы увидим позже в ходе курса, эта проекционная модель используется во всех разрабатываемых нами алгоритмах визуального восприятия, от обнаружения объектов до оценки производимого пространства. Наконец, вы узнали, как изображения представлены в программном обеспечении в виде массива, представляющего местоположения пикселей.Теперь вы готовы начать работать непосредственно с изображениями и программным обеспечением, как вы это сделаете в тестах на этой неделе. В следующем видео вы узнаете, как адаптировать модель камеры к конкретной камере, вычислив ее внутренние и внешние параметры камеры с помощью процесса, известного как калибровка камеры.
сложная проекционная матрица — Tech from the Front Line
В последнее время я работал над проектами компьютерного зрения, включая Tensorflow для глубокого обучения, OpenCV для компьютерного зрения и OpenGL для компьютерной графики.Меня особенно интересуют гибридные подходы, в которых я смешиваю материалы глубокого обучения, материалы opencv и классический конвейер OpenGL. Основная идея состоит в том, чтобы не рассматривать проблемы как проблемы черного ящика, использовать нейронную сеть и надеяться на лучшее. Основная идея скорее состоит в том, чтобы выполнять максимальный объем работы с проверенными технологиями и позволять глубокому обучению работать только с четко определенной подмножеством проблемы.
На этот раз я работал над проблемой дополненной реальности, где у меня есть изображение, и я хочу наложить на него что-то.В OpenCV по изображению вы можете оценить параметры камеры, которые называются «внутренними параметрами камеры». В модели камеры-обскуры OpenCV этими параметрами являются: fx (горизонтальное фокусное расстояние), fy (вертикальное фокусное расстояние), cx (координата X центра камеры), cy (координата Y центра камеры).
Это матрица камеры OpenCV:
Вы хотите наложить какой-либо материал на исходное изображение. Теперь, когда вы оценили параметр камеры OpenCV, вам нужно превратить его в матрицу проекции OpengL, чтобы вы могли визуализировать материал поверх исходного изображения с помощью графического конвейера OpenGL.Эта проблема вычисления матрицы проекции OpenGL из матрицы камеры OpenCV НЕ проста.
Прежде всего, матрица камеры OpenCV проецирует вершины прямо в координаты экрана. (ПРИМЕЧАНИЕ: не забудьте затем разделить на компонент z). Матрица проекции OpenGL проецирует вершины в пространство отсечения. Преобразование из пространства клипа в NDC (что означает деление на компонент w) обрабатывается OpenGL, а преобразование из NDC в пространство экрана также обрабатывается OpenGL. Итак, первая проблема заключается в том, что мы не рассматриваем одни и те же преобразования в точности.
Вторая проблема заключается в том, что в OpenGL вы обычно предполагаете, что центр вашей камеры находится в начале координат (это соглашение). В OpenCV это не так, параметры вашей камеры cx и cy позволяют располагать центр камеры где угодно, это такая же степень свободы, как и любая другая. 90% формул матриц проекции OpenGL, которые вы найдете в Интернете, не учитывают это.
В итоге проверил много источников:
https://blog.noctua-software.com/opencv-opengl-projection-matrix.html
http://kgeorge.github.io/2014/03/08/calculating-opengl-perspective-matrix-from-opencv-intrinsic-matrix
http://ksimek.github.io/2013/06/03/ calibrated_cameras_in_opengl /
https://jsantell.com/3d-projection
Но тот, который спас мне день, был этот: https://strawlab.org/2011/11/05/augmented-reality-with-OpenGL
Формула там точная (можно заменить K на матрицу камеры OpenCV).
Вот пример исходного кода, демонстрирующий, как можно спроецировать точку с помощью OpenCV и OpenGL и получить те же результаты (тем самым проверяя свои матрицы):
импортное CV2 | |
импортировать numpy как np | |
импорт математики | |
cx = 88 # главная точка x координата | |
cy = 109 # главная точка координата y | |
w = 178 # ширина изображения | |
h = 218 # высота изображения | |
near = 10 # около плоскости | |
far = 20 # дальний самолет | |
fovy = 45.0 / 360.0 * 2.0 * np.pi # 45 ° в радианах | |
f = h / 2 * math.tan (fovy / 2) #cf http://paulbourke.net/miscellaneous/lens/ (ПРИМЕЧАНИЕ: фокусное расстояние в пикселях) | |
# вычисляем матрицу камеры OpenCV | |
camera_mtx = np.array ([ | |
[f, 0, cx], | |
[0., f, cy], | |
[0., 0., 1.] | |
], dtype = np.float64) | |
# мы вычисляем соответствующую матрицу проекции opengl | |
#cf https://strawlab.org/2011/11/05/augmented-reality-with-OpenGL | |
# ПРИМЕЧАНИЕ: K00 = K11 = f, K10 = 0.0, K02 = cx, K12 = cy, K22 = 1.0 | |
opengl_mtx = np.array ([ | |
[2 * ширина / ширина, 0,0, (ширина — 2 * ширина) / ширина, 0.0], | |
[0,0, –2 * кадр / ч, (ч — 2 * цикл) / ч, 0,0], | |
[0.0, 0.0, (–далее — близко) / (далеко — близко), –2.0 * далеко * близко / (далеко – близко)], | |
[0,0, 0,0, –1,0, 0,0] | |
]) | |
# точка находится в пространстве камеры opencv (по оси Oz) | |
балла = np.array ([1.0, 2.0, 15.0]) # Примечание: координаты должны быть числами с плавающей запятой | |
#### Проекция OpenCV | |
screen_point, _ = cv2.projectPoints (np.array ([point]), np.zeros (3), np.zeros (3), camera_mtx, np.zeros (5)) | |
печать (screen_point) | |
# Примечание: мы получаем тот же результат с этим: (это то, что cv2.В основном projectPoints: умножает точки на матрицу камеры, а затем делит результат на координату z) | |
печать (camera_mtx.dot (точка) / точка [2]) | |
#### Проекция OpenGL | |
# переворачиваем точку z координатой, т.к. в opengl камера ориентирована по оси -Oz | |
балла [2] = –балл [2] | |
точка2 = нп.hstack ([point, 1.0]) # добавляем координаты вершины w (обычно выполняется в вершинном шейдере перед умножением на матрицу проекции) | |
# мы получаем точку в пространстве клипа | |
clip_point = opengl_mtx.dot (точка2) | |
# ПРИМЕЧАНИЕ: следующее «моделирует» то, что происходит в OpenGL после вершинного шейдера. | |
# Это необходимо, чтобы мы могли убедиться, что наша матрица проекции даст правильный результат при использовании в OpenGL | |
# мы получаем точку в NDC | |
ndc_point = clip_point / clip_point [3] | |
# получаем координаты экрана | |
viewport_point = (ndc_point + 1.0) /2.0 * np.array ([w, h, 1.0, 1.0]) | |
#opencv Соглашение Oy противоположно OpenGL, поэтому мы меняем координату y | |
viewport_point [1] = h — viewport_point [1] | |
печать (viewport_point) | |
# Теперь вы можете видеть, что viewport_point и screen_point имеют одинаковые координаты x / y! | |
# Это означает, что теперь вы можете из матрицы камеры OpenCv использовать OpenGl для рендеринга чего-либо поверх изображения, | |
# благодаря матрице проекции opengl, вычисленной из матрицы камеры opencv | |
# ПРИМЕЧАНИЕ: когда ближняя плоскость мала (несколько единиц) и когда фокусное расстояние маленькое (например: 10-12), | |
# оба результата имеют тенденцию расходиться.Я не уверен, почему формула начинает разваливаться при экстремальных значениях. |
Полный исходный код можно найти здесь: https://github.com/francoisruty/fruty_opencv-opengl-projection-matrix
Когда у вас есть матрица проекции OpenGL, вы можете визуализировать и наложить на изображение все, что вам нужно. Сначала я ожидал, что на этот шаг у меня уйдет 1-2 часа, а в итоге у меня ушло около 6 или 7 часов, поэтому я подумал, что поделюсь решением.
Нравится:
Нравится Загрузка…
СвязанныеОпубликовано Fruty
Мысли и мнения технического директора стартапа, увлеченного аэрокосмической и компьютерной графикой Просмотреть все сообщения Fruty
Опубликовано
Формирование изображения | Урок | Академия роботов
Теперь мы рассмотрим более математический способ описания процесса проекции, проекции точки из реального мира на плоскость изображения.В прошлой лекции мы рассмотрели это с очень интуитивной геометрической точки зрения. На этот раз мы посмотрим на это более математически.
Мы собираемся использовать модель проекции, отличную от той, что мы использовали в прошлый раз. Мы собираемся использовать модель, которая называется моделью «центральной проекции». Ключевыми элементами этой модели являются координатная рамка камеры, которую мы обозначаем буквой C. Плоскость изображения параллельна осям x и y камеры и расположена на расстоянии F в положительном направлении оси z.F эквивалентно фокусному расстоянию объектива, о котором мы говорили в прошлой лекции.
Теперь, чтобы спроецировать точку, мы пропускаем луч из точки в мире через плоскость изображения в исходную точку камеры. В модели с центральной проекцией вы заметите, что изображение не инвертируется, как это было в случае, о котором мы говорили в прошлой лекции. Мы можем написать уравнение для точки P в однородных координатах, мы умножим мировые координаты X, Y, Z на матрицу 3 x 4, чтобы получить однородные координаты проецируемой точки на плоскости изображения.
Давайте рассмотрим это уравнение более подробно. Довольно просто написать выражение для x̃, ỹ, z̃ через фокусное расстояние и мировую координату X, Y, Z. Мы можем преобразовать однородные координаты в декартовы координаты, используя правило, о котором мы говорили в предыдущем разделе. и с небольшой перестановкой мы можем привести уравнение к этой форме, и это точно такая же форма, как мы получили в предыдущей лекции, глядя на похожие треугольники.
Что действительно удобно и полезно в этом однородном представлении процесса формирования изображения, так это то, что оно полностью линейно. У нас нет этого явного деления на Z, расстояние между камерой и объектом. Это подразумевается в том, как мы пишем уравнения в однородной форме.
Давайте снова посмотрим на это уравнение, и мы можем разделить эту матрицу на две части. Матрица справа содержит элементы, равные либо 0, либо 1, либо f — фокусному расстоянию объектива. Итак, эта матрица выполняет масштабирование и масштабирование.Это функция фокусного расстояния нашего объектива. Матрица слева имеет интересную форму, это всего лишь 3 x 4, и эта матрица выполняет уменьшение размерности, сжимая точки из трех измерений в два.
И пока мы считаем плоскость изображения сплошной. На самом деле плоскость изображения квантуется. Он состоит из массивного массива светочувствительных элементов, соответствующих пикселям выходного изображения. Размер каждого пикселя в этой сетке я обозначу греческой буквой ро.Таким образом, пиксели имеют равную ширину и высоту роу. Пиксели действительно очень маленькие, поэтому ширина и высота пикселя часто составляют порядка 10 микрон, может быть, немного больше, может быть, немного меньше.
Что нам теперь нужно сделать, так это преобразовать координату P, которую мы вычислили ранее и которая была в единицах метров по отношению к началу плоскости изображения.
Нам нужно преобразовать его в единицы пикселей, и наша система координат пикселей имеет другое происхождение, о котором мы говорили в предыдущих лекциях.Координаты пикселей отсчитываются от верхнего левого угла изображения, поэтому нам нужно выполнить масштабирование, и нам нужно выполнить сдвиг, и это простая линейная операция. Итак, если у нас есть декартовы координаты x и y точки P на плоскости изображения, мы можем преобразовать их в эквивалентную координату пикселя, которую мы обозначаем координатами u и v, и мы можем представить это снова в однородной форме.
Здесь мы умножаем на матрицу, элементы матрицы — это размеры пикселя Pu и Pv и координаты того, что называется главной точкой.Главная точка — координата пикселя, где ось z исходного кадра пересекает плоскость изображения.
Однородные пиксельные координаты могут быть преобразованы в более привычные декартовы пиксельные координаты u и v с помощью правила преобразования, которое мы рассмотрели ранее.
По сути, мы берем первый и второй элементы однородного вектора и делим его на третий элемент однородного вектора.
Теперь мы можем собрать все эти части вместе и написать полную модель камеры в виде трех матриц.Произведение первых двух матриц обычно обозначается символом K, и мы называем их внутренними параметрами. Все числа в этих двух матрицах являются функциями самой камеры. Неважно, где камера, куда она направлена, это всего лишь функция камеры. Эти числа включают высоту и ширину пикселей на плоскости изображения, координаты главной точки и фокусное расстояние объектива.
Третья матрица описывает внешние параметры, которые описывают, где находится камера, но ничего не говорят о типе камеры.
Элементы в этой матрице являются функцией относительной позы камеры по отношению к кадру начала координат мира. Фактически, это противоположность xi C.
Произведение всех этих матриц вместе называется матрицей камеры и часто обозначается символом C.
Таким образом, эта единственная матрица является единственной матрицей 3 x 4 — это все, что нам нужно для описания отображения от мировой координаты, X, Y и Z до однородного представления координаты пикселя на плоскости изображения.Эта координата плоскости однородного изображения может быть преобразована в знакомую координату плоскости изображения в декартовой системе координат, используя это правило преобразования. Итак, это очень простой и лаконичный способ выполнения перспективной проекции.
Давайте теперь рассмотрим, что происходит, когда я ввожу ненулевой масштабный коэффициент λ. Однородные элементы координат ũ, ṽ и w̃ все будут масштабированы по λ. Когда я конвертирую их в декартову форму, член λ будет разложен на числитель и знаменатель, поэтому результат не изменится.Это особое преимущество записи отношений в однородной форме. Это дает нам то, что называется масштабной дисперсией.
Поскольку мы можем умножить матрицу на произвольный масштабный коэффициент, это означает, что мы можем записать матрицу камеры в несколько упрощенной форме, которую мы называем нормализованной матрицей камеры. Мы делаем это, выбирая один конкретный элемент этой матрицы, имеющий значение 1, и обычно мы выбираем нижний правый элемент и устанавливаем его на 1.
Эта нормализованная матрица камеры по-прежнему содержит всю информацию для полного описания процесса формирования изображения.Он содержит фокусное расстояние объектива, размер пикселей, координату главной точки и положение и ориентацию камеры в трехмерном пространстве. И, наконец, мы можем преобразовать однородные пиксельные координаты в более знакомые декартовы пиксельные координаты, которые мы обозначим через u и v.
Проекция вида моделиWebGL — веб-API
В этой статье рассматривается, как принимать данные в проекте WebGL и проецировать их в нужные места для отображения на экране.Это предполагает знание базовой математики матриц с использованием матриц переноса, масштабирования и вращения. В нем объясняются три основных матрицы, которые обычно используются при создании 3D-сцены: матрицы модели, вида и проекции.
Индивидуальные преобразования точек и многоугольников в пространстве в WebGL обрабатываются основными матрицами преобразования, такими как перенос, масштаб и поворот. Эти матрицы могут быть составлены вместе и сгруппированы особым образом, чтобы сделать их полезными для рендеринга сложных 3D-сцен.Эти составные матрицы в конечном итоге перемещают исходные данные модели в специальное координатное пространство, называемое пространством клипов . Это куб шириной 2 единицы с центром в точке (0,0,0) и углами в диапазоне от (-1, -1, -1) до (1,1,1). Это пространство клипа сжимается до двухмерного пространства и растрируется в изображение.
Первая матрица, обсуждаемая ниже, — это матрица модели , которая определяет, как вы берете данные исходной модели и перемещаете их в трехмерном мировом пространстве. Матрица проекции используется для преобразования координат мирового пространства в координаты пространства клипа.Обычно используемая проекционная матрица перспективная проекционная матрица используется для имитации эффектов типичной камеры, служащей в качестве замены для зрителя в виртуальном трехмерном мире. Матрица вида отвечает за перемещение объектов в сцене для имитации положения изменяемой камеры, изменяя то, что зритель может видеть в данный момент.
В следующих разделах подробно рассматриваются идеи, лежащие в основе и реализация матриц модели, вида и проекции.Эти матрицы являются основой для перемещения данных на экране и представляют собой концепции, выходящие за рамки отдельных фреймворков и механизмов.
В программе WebGL данные обычно загружаются в графический процессор с его собственной системой координат, а затем вершинный шейдер преобразует эти точки в специальную систему координат, известную как пространство отсечения . Любые данные, выходящие за пределы пространства клипа, обрезаются и не отображаются. Однако, если треугольник пересекает границу этого пространства, он разбивается на новые треугольники, и остаются только те части новых треугольников, которые находятся в пространстве отсечения.
На приведенном выше рисунке показано пространство клипа, в которое должны уместиться все точки. Это куб, по две единицы на каждой стороне, с одним углом в точке (-1, -1, -1) и противоположным углом в точке (1,1,1). Центр куба — точка (0,0,0). Эта система координат размером 8 кубических метров, используемая пространством клипов, известна как нормализованные координаты устройства (NDC). Вы можете время от времени использовать этот термин при исследовании кода WebGL и работе с ним.
В этом разделе мы поместим наши данные напрямую в систему координат пространства клипа.Обычно используются данные модели, которые находятся в некоторой произвольной системе координат, а затем преобразуются с использованием матрицы, преобразуя координаты модели в систему координат пространства клипа. В этом примере проще всего проиллюстрировать, как работает пространство клипа, используя значения координат модели в диапазоне от (-1, -1, -1) до (1,1,1). Приведенный ниже код создаст 2 треугольника, которые будут рисовать квадрат на экране. Глубина Z в квадратах определяет, что будет нарисовано сверху, когда квадраты занимают одно и то же пространство. Меньшие значения Z отображаются поверх больших значений Z.
Пример WebGLBox
В этом примере будет создан пользовательский объект WebGLBox
, который будет рисовать 2D-блок на экране.
Примечание : Код для каждого примера WebGLBox доступен в этом репозитории github и организован по разделам. Кроме того, внизу каждого раздела есть ссылка JSFiddle.
Конструктор WebGLBox
Конструктор выглядит так:
function WebGLBox () {
this.canvas = документ.getElementById ('холст');
this.canvas.width = window.innerWidth;
this.canvas.height = window.innerHeight;
this.gl = MDN.createContext (холст);
var gl = this.gl;
this.webglProgram = MDN.createWebGLProgramFromIds (gl, 'вершинный шейдер', 'фрагмент-шейдер');
gl.useProgram (this.webglProgram);
this.positionLocation = gl.getAttribLocation (this.webglProgram, 'позиция');
this.colorLocation = gl.getUniformLocation (this.webglProgram, 'цвет');
gl.enable (gl.DEPTH_TEST);
}
WebGLBox ничья
Теперь мы создадим метод рисования прямоугольника на экране.
WebGLBox.prototype.draw = function (settings) {
var data = new Float32Array ([
settings.left, settings.bottom, settings.depth,
settings.right, settings.bottom, settings.depth,
settings.left, settings.top, settings.depth,
settings.left, settings.top, settings.depth,
settings.right, settings.bottom, settings.depth,
settings.right, settings.top, settings.depth
]);
var gl = this.gl;
var buffer = gl.createBuffer ();
gl.bindBuffer (gl.ARRAY_BUFFER, буфер);
gl.bufferData (gl.ARRAY_BUFFER, данные, gl.STATIC_DRAW);
gl.enableVertexAttribArray (this.positionLocation);
gl.vertexAttribPointer (this.positionLocation, 3, gl.FLOAT, false, 0, 0);
gl.uniform4fv (this.colorLocation, settings.color);
gl.drawArrays (gl.TRIANGLES, 0, 6);
}
Шейдеры — это биты кода, написанные на GLSL, которые берут наши точки данных и в конечном итоге выводят их на экран. Для удобства эти шейдеры хранятся в элементе
,который вводится в программу через пользовательскую функциюMDN.createWebGLProgramFromIds()
.Эта функция является частью набора служебных функций,написанных для этих руководств,и здесь не рассматривается подробно.Эта функция обрабатывает основы взятия некоторого исходного кода GLSL и его компиляции в программу WebGL.Функция принимает три параметра:контекст для рендеринга программы,идентификатор элемента,содержащего вершинный шейдер,и идентификатор элемента
,содержащего фрагментный шейдер.Вершинный шейдер позиционирует вершины,а фрагментный шейдер окрашивает каждый пиксель.
Сначала взгляните на вершинный шейдер,который будет перемещать вершины на экране:
позиция атрибута vec3;пустая функция(){gl_Position=vec4(позиция,1.0);}
Затем,чтобы фактически растрировать данные в пиксели,фрагментный шейдер оценивает все для каждого пикселя,устанавливая один цвет.Графический процессор вызывает функцию шейдера для каждого пикселя,который ему необходимо отобразить;задача шейдера-вернуть цвет,который будет использоваться для этого пикселя.
прецизионный поплавок среднего размера;равномерный цвет vec4;пустая функция(){gl_FragColor=цвет;}
С этими настройками пора рисовать прямо на экране,используя координаты пространства клипа.
var box=new WebGLBox();
Сначала нарисуйте красный прямоугольник посередине.
box.draw({верх:0,5,низ:-0,5,осталось:-0,5,справа:0,5,глубина:0,цвет:[1,0.4,0,4,1]});
Затем нарисуйте зеленую рамку вверху и за красной рамкой.
box.draw({верх:0,9,внизу:0,осталось:-0,9,справа:0,9,глубина:0,5,цвет:[0,4,1,0,4,1]});
Наконец,для демонстрации того,что на самом деле происходит отсечение,этот прямоугольник не отрисовывается,потому что он полностью находится вне пространства клипа.Глубина вне диапазона от-1,0 до 1.0 диапазон.
box.draw({верх:1,внизу:-1,осталось:-1,справа:1,глубина:-1,5,цвет:[0,4,0,4,1,1]});
Результаты
Посмотреть на JSFiddle
Упражнение
Полезным упражнением на этом этапе является перемещение прямоугольников в пространстве клипа путем изменения кода,чтобы понять,как точки обрезаются и перемещаются в пространстве клипа.Попробуйте нарисовать картинку в виде квадратного смайлика с фоном.
Основная строка предыдущего вершинного шейдера пространства отсечения содержала этот код:
gl_Position=vec4(position,1.0);
Переменнаяposition
была определена в методеdraw()
и передана шейдеру как атрибут.Это трехмерная точка,но переменнаяgl_Position
,которая в конечном итоге передается по конвейеру,на самом деле является четырехмерной-вместо(x,y,z)
это(x,y,z,w)
.Послеz
нет буквы,поэтому по соглашению это четвертое измерение обозначаетсяw
.В приведенном выше примере координатаw
установлена на 1.0.
Возникает очевидный вопрос:"Зачем нужно дополнительное измерение?"Оказывается,это дополнение позволяет использовать множество хороших техник для управления трехмерными данными.Это добавленное измерение вводит понятие перспективы в систему координат;установив его,мы можем отобразить трехмерные координаты в двухмерном пространстве,тем самым позволяя двум параллельным линиям пересекаться по мере их удаления.Значениеw
используется в качестве делителя для других компонентов координаты,так что истинные значенияx
,y
иz
вычисляются какx/w
,y/w
ипо ширине
(ипо ширине
также будетпо ширине
,становясь 1).
Трехмерная точка определяется в типичной декартовой системе координат.Добавленное четвертое измерение превращает эту точку в однородную координату.Он по-прежнему представляет собой точку в трехмерном пространстве,и можно легко продемонстрировать,как построить этот тип координат с помощью пары простых функций.
функция декартовоГомогенная(точка)
пусть x=точка[0];пусть y=point[1];пусть z=point[2];return[x,y,z,1];}
function homogenToCartesian(point){пусть x=точка[0];пусть y=point[1];пусть z=point[2];пусть w=точка[3];return[x/w,y/w,z/w];}
Как упоминалось ранее и показано в функциях выше,компонент w делит компоненты x,y и z.Когда компонент w представляет собой ненулевое действительное число,тогда однородная координата легко переводится обратно в нормальную точку в декартовом пространстве.Что произойдет,если компонент w равен нулю?В JavaScript возвращаемое значение будет следующим.
однородно-декартово([10,4,5,0]);
Это оценивается как:[Бесконечность,Бесконечность,Бесконечность]
.
Эта однородная координата представляет некоторую бесконечно удаленную точку.Это удобный способ представить луч,выходящий из исходной точки в определенном направлении.Помимо луча,его также можно рассматривать как представление вектора направления.Если эта однородная координата умножается на матрицу с переносом,то перенос эффективно удаляется.
Когда числа на компьютерах очень большие(или очень маленькие),они начинают становиться все менее и менее точными,потому что для их представления используется очень много единиц и нулей.Чем больше операций выполняется с большими числами,тем больше ошибок накапливается в результате.При делении на w это может эффективно повысить точность очень больших чисел за счет работы с двумя потенциально меньшими числами,менее подверженными ошибкам.
Последним преимуществом использования однородных координат является то,что они очень хорошо подходят для умножения на матрицы 4x4.Вершина должна соответствовать по крайней мере одному из измерений матрицы,чтобы ее можно было умножить на нее.Матрица 4x4 может использоваться для кодирования множества полезных преобразований.Фактически,типичная матрица перспективной проекции использует деление на компонент w для достижения своего преобразования.
Отсечение точек и многоугольников из пространства отсечения фактически происходит после того,как однородные координаты были преобразованы обратно в декартовы координаты(путем деления на w).Это последнее пространство известно какнормализованные координаты устройстваили NDC.
Чтобы начать играть с этой идеей,предыдущий пример можно изменить,чтобы разрешить использование компонентаw
.
var data=new Float32Array([settings.left,settings.bottom,settings.depth,settings.w,settings.right,settings.bottom,settings.depth,settings.w,settings.left,settings.top,settings.depth,settings.w,settings.left,settings.top,settings.глубина,settings.w,settings.right,settings.bottom,settings.depth,settings.w,settings.right,settings.top,settings.depth,settings.w]);
Затем вершинный шейдер использует переданную четырехмерную точку.
атрибут vec4 position;пустая функция(){gl_Position=позиция;}
Сначала мы рисуем красный прямоугольник посередине,но устанавливаем W равным 0,7.При делении координат на 0,7 все они будут увеличены.
box.draw({верх:0.5,низ:-0,5,осталось:-0,5,справа:0,5,w:0,7,глубина:0,цвет:[1,0,4,0,4,1]});
Теперь мы рисуем зеленый прямоугольник вверху,но сжимаем его,задав для компонента w значение 1,1
box.draw({верх:0,9,внизу:0,осталось:-0,9,справа:0,9,w:1.1,глубина:0,5,цвет:[0.4,1,0,4,1]});
Этот последний блок не отображается,потому что он находится вне области клипа.Глубина находится вне диапазона от-1,0 до 1,0.
box.draw({верх:1,внизу:-1,осталось:-1,справа:1,w:1,5,глубина:-1,5,цвет:[0,4,0,4,1,1]});
Результаты
Упражнения
Размещение точек непосредственно в пространстве клипа имеет ограниченное применение.В реальных приложениях не все исходные координаты уже находятся в координатах пространства клипа.Поэтому в большинстве случаев вам необходимо преобразовать данные модели и другие координаты в пространство отсечения.Скромный куб-простой пример того,как это сделать.Данные куба состоят из позиций вершин,цветов граней куба и порядка позиций вершин,составляющих отдельные многоугольники(в группах по 3 вершины для построения треугольников,составляющих грани куба).Позиции и цвета хранятся в буферах GL,отправляются шейдеру как атрибуты,а затем обрабатываются индивидуально.
Наконец,вычисляется и устанавливается единая матрица модели.Эта матрица представляет преобразования,которые должны быть выполнены в каждой точке,составляющей модель,чтобы переместить ее в правильное пространство и выполнить любые другие необходимые преобразования в каждой точке модели.Это применимо не только к каждой вершине,но и к каждой отдельной точке на каждой поверхности модели.
В этом случае для каждого кадра анимации серия матриц масштабирования,поворота и трансляции перемещает данные в желаемое место в пространстве клипа.Куб имеет размер от пространства клипа(-1,-1,-1)до(1,1,1),поэтому его необходимо уменьшить,чтобы не заполнить все пространство клипа.Эта матрица отправляется прямо в шейдер,предварительно умноженная в JavaScript.
В следующем примере кода определяется метод объектаCubeDemo
,который будет создавать матрицу модели.Он использует пользовательские функции для создания и умножения матриц,как определено в общем коде MDN WebGL.Новая функция выглядит так:
CubeDemo.prototype.computeModelMatrix=function(now){var scale=MDN.scaleMatrix(0,5,0,5,0,5);var rotateX=MDN.rotateXMatrix(теперь*0,0003);var rotateY=MDN.rotateYMatrix(теперь*0,0005);var position=MDN.translateMatrix(0,-0,1,0);this.transforms.model=MDN.multiplyArrayOfMatrices([позиция,rotateY,rotateX,шкала]);};
Чтобы использовать это в шейдере,он должен быть установлен в одно и то же место.Места для униформы сохранены в объектеlocation
,показанном ниже:
this.locations.model=gl.getUniformLocation(webglProgram,'модель');
И,наконец,униформа устанавливается на это место.Это передает матрицу графическому процессору.
gl.uniformMatrix4fv(this.locations.model,false,new Float32Array(this.transforms.model));
В шейдере каждая вершина положения сначала преобразуется в однородную координату(объектvec4
),а затем умножается на матрицу модели.
gl_Position=модель*vec4(position,1.0);
Примечание:В JavaScript для умножения матриц требуется специальная функция,а в шейдере оно встроено в язык с помощью простого оператора*.
Результаты
Посмотреть на JSFiddle
На этом этапе значение w преобразованной точки все еще равно 1.0.У куба по-прежнему нет перспективы.В следующем разделе мы рассмотрим эту настройку и изменим значения w,чтобы обеспечить некоторую перспективу.
Упражнения
Простой способ получить некоторое представление о нашей модели куба-взять координату Z и скопировать ее в координату w.Обычно при преобразовании декартовой точки в однородную она становится(x,y,z,1)
,но мы собираемся установить ее примерно как(x,y,z,z)
.На самом деле мы хотим убедиться,что z больше 0 для точек обзора,поэтому мы немного изменим его,изменив значение на((1.0+z)*scaleFactor)
.Это займет точку,которая обычно находится в пространстве клипа(от-1 до 1),и переместит ее в пространство,более похожее на(от 0 до 1),в зависимости от того,какой масштабный коэффициент установлен.Масштабный коэффициент изменяет окончательное значение w в целом на большее или меньшее.
Код шейдера выглядит так.
vec4 transformedPosition=model*vec4(position,1.0);float scaleFactor=0,5;float w=(1.0+transformedPosition.z)*scaleFactor;gl_Position=vec4(transformedPosition.xyz,w);
Результаты
Просмотр на JSFiddle
Видите этот маленький синий треугольник?Это дополнительная грань,добавленная к нашему объекту,потому что поворот нашей формы заставил этот угол выходить за пределы пространства клипа,что привело к тому,что угол был обрезан.См.Раздел Матрица перспективной проекции ниже,чтобы узнать,как использовать более сложные матрицы для управления и предотвращения отсечения.
Exercise
Если это звучит немного абстрактно,откройте вершинный шейдер,поиграйте с масштабным коэффициентом и посмотрите,как он сжимает вершины ближе к поверхности.Полностью измените значения компонента w для действительно странного представления пространства.
В следующем разделе мы сделаем этот шаг копирования Z в слот w и превратим его в матрицу.
Последний шаг заполнения компонента w может быть выполнен с помощью простой матрицы.Начнем с единичной матрицы:
var identity=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1,];MDN.multiplyPoint(идентичность,[2,3,4,1]);
Затем переместите 1 последнего столбца на одну позицию вверх.
var copyZ=[1,0,0,0,0,1,0,0,0,0,1,1,0,0,0,0,];MDN.multiplyPoint(copyZ,[2,3,4,1]);
Однако в последнем примере мы выполнили(z+1)*scaleFactor
:
var scaleFactor=0,5;var simpleProjection=[1,0,0,0,0,1,0,0,0,0,1,scaleFactor,0,0,0,scaleFactor,];MDN.multiplyPoint(simpleProjection,[2,3,4,1]);
Разбив его немного дальше,мы можем увидеть,как это работает:
var x=(2*1)+(3*0)+(4*0)+(1*0)
var y=(2*0)+(3*1)+(4*0)+(1*0)
var z=(2*0)+(3*0)+(4*1)+(1*0)
var w=(2*0)+(3*0)+(4*scaleFactor)+(1*scaleFactor)
Последнюю строку можно упростить до:
w=(4*scaleFactor)+(1*scaleFactor)
Затем вычитая scaleFactor,получаем:
w=(4+1)*scaleFactor
Что в точности совпадает с(z+1)*scaleFactor
,который мы использовали в предыдущем примере.
В демонстрационной коробке добавлен дополнительный методcomputeSimpleProjectionMatrix()
.Это вызывается в методеdraw()
,и ему передается масштабный коэффициент.Результат должен быть идентичен последнему примеру:
CubeDemo.prototype.computeSimpleProjectionMatrix=function(scaleFactor){this.transforms.projection=[1,0,0,0,0,1,0,0,0,0,1,scaleFactor,0,0,0,scaleFactor];};
Хотя результат идентичен,важный шаг здесь находится в вершинном шейдере.Вместо того,чтобы изменять вершину напрямую,она умножается на дополнительную матрицу проекции,которая(как следует из названия)проецирует 3D-точки на поверхность 2D-чертежа:
gl_Position=проекция*модель*vec4(позиция,1.0);
Результаты
Прежде чем мы перейдем к рассмотрению того,как вычислить матрицу перспективной проекции,нам нужно представить концепцию усеченной пирамиды обзора(также известной как усеченная пирамида обзора).Это область пространства,содержимое которой видно пользователю в текущий момент.Это трехмерная область пространства,определяемая полем обзора и расстояниями,указанными как ближайший и самый дальний контент,который должен отображаться.
Во время рендеринга нам нужно определить,какие полигоны нужно отрендерить,чтобы представить сцену.Это то,что определяет усеченная пирамида.Но что вообще такое усеченная пирамида?
Усеченная пирамида-это трехмерное тело,которое получается в результате взятия любого твердого тела и срезания двух его частей с использованием двух параллельных плоскостей.Рассмотрим нашу камеру,которая просматривает область,которая начинается непосредственно перед ее объективом и простирается вдаль.Видимая область представляет собой четырехстороннюю пирамиду с вершиной у линзы,четыре стороны которой соответствуют границам диапазона периферического зрения,а основание-на самом дальнем расстоянии,которое она может видеть,например:
Если бы мы использовали это для определения полигонов,которые будут визуализироваться в каждом кадре,нашему модулю визуализации потребуется визуализировать каждый многоугольник внутри этой пирамиды,вплоть до бесконечности,включая также многоугольники,которые находятся очень близко к линзе-вероятно,слишком близко,чтобы быть полезны(и,конечно,включая вещи,которые настолько близки,что настоящий человек не сможет сосредоточиться на них в той же обстановке).
Итак,первый шаг в уменьшении количества полигонов,которые нам нужно вычислить и визуализировать,-это превратить эту пирамиду в усеченную пирамиду.Две плоскости,которые мы будем использовать для отсечения вершин,чтобы уменьшить количество полигонов,-этоближняя плоскость отсеченияи дальняя плоскость отсечения.
В WebXR ближняя и дальняя плоскости отсечения определяются путем указания расстояния от линзы до ближайшей точки на плоскости,перпендикулярной направлению просмотра.Все,что находится ближе к линзе,чем ближняя плоскость отсечения,или дальше от нее,чем дальняя плоскость отсечения,удаляется.В результате получается усеченная пирамида,которая выглядит так:
Набор объектов для рендеринга для каждого кадра по существу создается,начиная с набора всех объектов в сцене.Затем из набора удаляются любые объекты,которые находятся нацеликом наза пределами усеченной пирамиды обзора.Затем объекты,которые частично выступают за пределы усеченной пирамиды,обрезаются путем отбрасывания всех полигонов,которые полностью находятся за пределами усеченной пирамиды,и путем отсечения многоугольников,которые пересекаются за пределами усеченной пирамиды,чтобы они больше не выходили из нее.
Как только это будет сделано,мы получим самый большой набор полигонов,которые полностью находятся в пределах усеченной области обзора.Этот список обычно дополнительно сокращается с использованием таких процессов,как отбраковка обратной стороны(удаление полигонов,обратная сторона которых обращена к камере)и отсечение окклюзии с использованием определения скрытой поверхности(удаление полигонов,которые не видны,потому что они полностью заблокированы полигонами,которые ближе к объективу).
К этому моменту мы шаг за шагом создали нашу собственную настройку 3D-рендеринга.Однако в текущем коде,который мы создали,есть некоторые проблемы.Во-первых,он искажается всякий раз,когда мы меняем размер окна.Во-вторых,наша простая проекция не обрабатывает широкий диапазон значений данных сцены.Большинство сцен не работают в пространстве клипа.Было бы полезно определить,какое расстояние имеет отношение к сцене,чтобы не потерять точность при преобразовании чисел.Наконец,очень полезно иметь точный контроль над тем,какие точки помещаются внутри и вне пространства клипа.В предыдущих примерах углы куба иногда обрезались.
Матрица перспективной проекции-это тип матрицы проекции,который удовлетворяет всем этим требованиям.Математика также становится более сложной и не будет полностью объяснена в этих примерах.Короче говоря,он сочетает в себе деление на w(как и в предыдущих примерах)с некоторыми изобретательными манипуляциями,основанными на подобных треугольниках.Если вы хотите прочитать полное объяснение математики,стоящей за этим,ознакомьтесь с некоторыми из следующих ссылок:
Одно важное замечание относительно матрицы перспективной проекции,используемой ниже,-это то,что она переворачивает ось z.В пространстве клипа z+уходит от зрителя,в то время как с этой матрицей он приближается к зрителю.
Причина переворота оси z заключается в том,что система координат пространства клипа является левосторонней системой координат(в которой ось z направлена от зрителя к экрану),в то время как в математике,физике и трехмерном моделировании принято считать,что так же,как для системы координат вид/глаз в OpenGL,заключается в использовании правой системы координат(ось z направлена за пределы экрана в сторону зрителя).Подробнее об этом в соответствующих статьях Википедии:Декартова система координат,Правило правой руки.
Давайте взглянем на функциюpectiveMatrix()
,которая вычисляет матрицу перспективной проекции.
MDN.perspectiveMatrix=function(fieldOfViewInRadians,aspectRatio,near,far){var f=1.0/Math.tan(fieldOfViewInRadians/2);var rangeInv=1/(ближний-дальний);возвращаться[f/аспектное отношение,0,0,0,0,е,0,0,0,0,(близко+далеко)*rangeInv,-1,0,0,близко*далеко*rangeInv*2,0];}
Четыре параметра этой функции:
В последней версии демонстрационного блока методcomputeSimpleProjectionMatrix()
был заменен методомcomputePerspectiveMatrix()
.
CubeDemo.prototype.computePerspectiveMatrix=function(){var fieldOfViewInRadians=Math.PI*0,5;вар аспектRatio=окно.innerWidth/window.innerHeight;var nearClippingPlaneDistance=1;var farClippingPlaneDistance=50;this.transforms.projection=MDN.perspectiveMatrix(fieldOfViewInRadians,соотношение сторон,nearClippingPlaneDistance,farClippingPlaneDistance);};
Код шейдера идентичен предыдущему примеру:
gl_Position=проекция*модель*vec4(позиция,1.0);
Кроме того(не показано),матрицы положения и масштаба модели были изменены,чтобы вывести ее из пространства клипа в большую систему координат.
Результаты
Упражнения
В то время как в некоторых графических библиотеках есть виртуальная камера,которую можно позиционировать и указывать при создании сцены,в OpenGL(и,соответственно,в WebGL)ее нет.Здесь на помощь приходит матрица вида.Ее задача-перемещать,вращать и масштабировать объекты в сцене так,чтобы они располагались в нужном месте относительно зрителя с учетом положения и ориентации зрителя.
Моделирование камеры
При этом используется один из фундаментальных аспектов специальной теории относительности Эйнштейна:принцип системы отсчета и относительного движения гласит,что с точки зрения наблюдателя вы можете моделировать изменение положения и ориентации зритель,применив противоположное изменение к объектам в сцене.В любом случае результат кажется зрителю идентичным.
Представьте коробку,стоящую на столе,и камеру,стоящую на столе на расстоянии одного метра,направленную на коробку,передняя часть которой направлена в сторону камеры.Затем подумайте о том,чтобы отодвинуть камеру от коробки,пока она не окажется на расстоянии двух метров(добавив метр к положению камеры по оси Z),а затем сдвиньте камеру на 10 сантиметров влево.Коробка удаляется от камеры на эту величину и немного сдвигается вправо,тем самым становясь меньше для камеры и открывая небольшую часть своей левой стороны для камеры.
Теперь давайте переустановим сцену,поместив коробку обратно в исходную точку,так чтобы камера находилась в двух метрах от коробки и смотрела прямо на нее.Однако на этот раз камера заблокирована на столе и не может быть перемещена или повернута.Вот на что похожа работа в WebGL.Итак,как нам имитировать перемещение камеры в пространстве?
Вместо перемещения камеры назад и влево мы применяем обратное преобразование к прямоугольнику:мы перемещаем прямоугольникназад на один метр,а затем на 10 сантиметров вправо.Результат с точки зрения каждого из двух объектов идентичен.
<<<вставить изображение(я)сюда>>>
Последним шагом во всем этом является создание матрицы вида,которая преобразует объекты в сцене таким образом,чтобы они располагались так,чтобы имитировать текущее местоположение и ориентацию камеры.Наш код в его нынешнем виде может перемещать куб в мировом пространстве и проецировать все,чтобы иметь перспективу,но мы по-прежнему не можем перемещать камеру.
Представьте,что вы снимаете фильм с помощью физической камеры.У вас есть свобода разместить камеру практически в любом месте,где вы хотите,и направить камеру в любом направлении,которое вы выберете.Чтобы смоделировать это в трехмерной графике,мы используем матрицу вида для имитации положения и поворота этой физической камеры.
В отличие от матрицы модели,которая напрямую преобразует вершины модели,матрица вида перемещает абстрактную камеру.На самом деле вершинный шейдер по-прежнему только перемещает модели,в то время как «камера» остается на месте.Чтобы это работало правильно,необходимо использовать обратную матрицу преобразования.Обратная матрица,по сути,меняет преобразование,поэтому,если мы перемещаем обзор камеры вперед,обратная матрица заставляет объекты в сцене перемещаться назад.
Следующий методcomputeViewMatrix()
анимирует матрицу представления,перемещая ее внутрь и наружу,влево и вправо.
CubeDemo.prototype.computeViewMatrix=function(now){var moveInAndOut=20*Math.sin(теперь*0,002);var moveLeftAndRight=15*Math.sin(теперь*0,0017);var position=MDN.translateMatrix(moveLeftAndRight,0,50+moveInAndOut);var matrix=MDN.multiplyArrayOfMatrices([позиция]);this.transforms.view=MDN.invertMatrix(матрица);};
Теперь шейдер использует три матрицы.
gl_Position=проекция*вид*модель*vec4(позиция,1.0);
После этого шага конвейер графического процессора отсекает вершины вне диапазона и отправляет модель вниз во фрагментный шейдер для растеризации.
Результаты
Связь систем координат
На этом этапе было бы полезно сделать шаг назад,посмотреть и обозначить различные системы координат,которые мы используем.Во-первых,вершины куба определены в пространстве модели.Для перемещения модели по сцене.эти вершины необходимо преобразовать в мировое пространство,применяя матрицу модели.
модельное пространство → модельная матрица → мировое пространство
Камера еще ничего не сделала,и точки нужно снова переместить.В настоящее время они находятся в мировом пространстве,но их необходимо переместить в пространство обзора(с использованием матрицы обзора),чтобы представить размещение камеры.
мировое пространство → просмотреть матрицу → просмотреть пространство
Наконец,необходимо добавить проекцию(в нашем случае матрицу перспективной проекции),чтобы отобразить мировые координаты в координаты пространства клипа.