sundarapandian kuttymovies
logo openscad

Kuttymovies !free!: Sundarapandian

Знакомимся с OpenSCAD.

Небольшая ознакомительная часть, чтобы понять, с чем собственно придётся иметь дело, и стоит ли вообще начинать. Ниже будет изложено моё личное мнение, которое не претендует на истину в первой инстанции. Людей много и вкусы у всех разные. Тем не менее как человек имеющий опыт работы в этой системе проектирования я могу дать свою оценку.

Начну пожалуй с того, что начинающему 3D проектировщику стоит определиться с целью использования CAD. Если ваша цель это мультимедиа и скульптура - данный CAD вам не подойдёт (если только вы не работаете в жанре примитивизма, кубизма или не собрались сделать 3D модель свинки ПЕПЫ). Если вы хотите проектировать технические объекты относительно невысокой сложности вы на верном пути... Посмотрим с чем мы имеем дело.

Достоинства:

Недостатки:

В итоге мы имеем своего рода Windows Блокнот в мире CAD. Просто, бесплатно, удобно для быстрых записей, но иногда много чего не хватает. Лично мне проект очень нравится. Использую в 3D печати. Советую попробовать.

Пишем первый код на OpenSCAD.

Процесс установки программы не требует особых пояснений. Единственно стоит обратить внимание что есть 32, 64 битные варианты для Windows и вариант не требующий установки. После установки в открывшемся окне жмём создать и видим два поля. Слева окно для кода справа окно визуализации. Начинаем!

OpenSCAD - построение графических примитивов: куб, параллелепипед, сфера, цилиндр, конус, многогранник.

Параллелепипед с длинами сторон по X, Y, Z соответственно 10, 20, 30 в мм:
cube( size=[10,20,30], center=true );
true/false - располагать по центру или в положительных полуосях. Короткие варианты написания кода:
cube( [10, 20, 30], true );
cube( [10, 20, 30] );
если последний параметр не указан принимает значение false
a = [10, 15, 20]; cube(a);
здесь a - параметр (матрица) содержит в себе значение сторон
cube( 5 );
куб стороной 5мм в положительных полуосях;
параллелепипед
Сфера радиусом 8 мм, с разным разрешением $fn.
sphere(r=8, $fn=100); // Полное написание
sphere(8, $fn=20); // Короткое написание
sphere(8, $fn=4);
sphere(8, $fn=5);
Центр сферы всегда в начале координат.
Вместо $fn можно задать параметр $fa - угловое разрешение и $fs - размер грани в мм.
sphere(d=16, $fn=100); // Задать сферу через диаметр
сфера с разным параметром $fn
Через цилиндр можно задать конус, усечённый конус, пирамиду, усечённую пирамиду. Первый параметр высота цилиндра, следующие это нижний радиус, верхний радиус, центровка и число граней $fn.
cylinder(h=10, r1=8, r2=5, center=true, $fn=100); // полное написание
cylinder(10, 8, 0, true, $fn=100); // краткое написание
cylinder(10, 8, 8, true, $fn=100);
cylinder(10, 8, 5, true, $fn=4);
Варианты написания:
cylinder(h=10, d1=16, d2=10, true, $fn=100);// через диаметры оснований
cylinder(h=10, r1=8, d2=10, true, $fn=100);// через радиус и диаметр онований
cylinder(h=10, r=8, true, $fn=100);// если нужен просто цилиндр
цилиндр конус пирамида усечённый конус
Многогранник.
Через эту функцию можно задать любую поверхность. На практике используется редко. Почему? Думаю поймёте сами.
Постройка пирамиды.
Что требуется? Задать все вершины фигуры (points) в координатах [x, y, z]. Затем объединить в группу по 3 - получить треугольники, играющие роль граней (faces) многогранника.
polyhedron(
  points=[ [10,10,0], [10,-10,0], [-10,-10,0], [-10,10,0], [0,0,10] ],
  faces=[ [0,1,4], [1,2,4], [2,3,4], [3,0,4], [1,0,3], [2,1,3] ]			      
);
Точки (points) с координатой z=0 - это вершины основания пирамиды, a последняя с x=0, y=0, z=10 - это пик пирамиды.
Грани (faces) [0,1,4], [1,2,4], [2,3,4], [3,0,4] - это боковые треугольные грани, а последние две [1,0,3], [2,1,3] задают квадрат основания. Цифры в квадратных скобках, говорят какие точки объединить. Соответственно точки по порядку их следования 0 -> [10,10,0] , 1 -> [10,-10,0] и т.д.
многогранник построенный по заданным точкам

OpenSCAD основные операции, действия с объектами.

Перемещение объекта на x=10, y=10, z=0 относительно центра координат:
translate([10,10,0]) cube(10, true);
Если нужно переместить группу объектов заключаем их в фигурные скобки:
translate([10,10,0]) {/*Здесь код группы*/};
Применение нескольких вложенных переносов:
translate([10,10,0]) {
  cube(10, true);
  translate([0,0,5]) sphere(5, $fn=50);
};
Эквивалент примера выше:
translate([10,10,0]) cube(10, true);
translate([10,10,5]) sphere(5, $fn=50);
cмещение фигуры методом translate
Вращение.
На 75 градусов вокруг оси X:
rotate([75,0,0]) cube(10, true);
Вращение группы объектов:
rotate([75,0,0]){/*Здесь код группы*/};
Вращение + перемещение.
Две нижние строчки:
color([0,1,1]) translate([0,0,15]) rotate([75,0,0]) cube(10, true);
color([1,0,1]) rotate([75,0,0]) translate([0,0,15]) cube(10, true);
Дают разные результаты. Имеет значение последовательность действий. Бирюзовый куб сначала повёрнут на 75 градусов вокруг оси X, а потом смещён на 15 мм по оси z. Сиреневый куб сначала смещён на 15 мм, а потом повёрнут.
вращение фигуры методом rotate
Сложение (объединение).
union(){
  cylinder(30, 5, 5, true, $fn=50);
  rotate([60,0,0]) cylinder(30, 5, 5, true, $fn=50);
};
Любое количество простых или сложных объектов в фигурных скобках будут объединены.
Cумма двух фигур
Вычитание (разность).
Из простого объекта указанного первым будут вычитаться все что указано ниже него.
difference(){
  cylinder(30, 5, 5, true, $fn=50);
  rotate([60,0,0]) cylinder(30, 5, 5, true, $fn=50);
};
Из составного объекта указанного первым будут вычитаться все что указано ниже него.
difference(){
  union(){cylinder(30, 5, 5, true, $fn=50); cube(10, true);};
  rotate([60,0,0]) cylinder(30, 5, 5, true, $fn=50);
};
разность цилиндров
Произведение (пересечение). У объектов внутри фигурных скобок находится общая часть - она и остаётся.
intersection(){
  cylinder(30, 5, 5, true, $fn=50);
  rotate([60,0,0]) cylinder(30, 5, 5, true, $fn=50);
};
пересечение двух тел
Чтобы сделать объект видимым или прозрачным при вычитании или пересечении, достаточно поставить решётку перед фигурой, объединением и т.п. Модификатор очень удобен при отладке модели, когда не видно вычитаемых, пересекаемых фигур или если нужно заглянуть внутрь создаваемой модели.
translate([10,0,0]) difference(){
  cylinder(30, 5, 5, true, $fn=50);
  rotate([60,0,0]) #cylinder(30, 5, 5, true, $fn=50);
};
или
translate([-10,0,0]) intersection(){
  #cylinder(30, 5, 5, true, $fn=50);
  rotate([60,0,0]) cylinder(30, 5, 5, true, $fn=50);
};
отладка модели
Сжатие. Растяжение.
scale([2,2,0.5]) sphere(8, $fn=30);
Соответственно по оси X и Y сферу растянули в 2 раза, а по оси Z сжали в 2 раза.
сжатие сферы по оси Z и растяжение по осям X Y

Пример работы в OpenSCAD. Проектируем колесо для детской машинки.

Исходный цилиндр.
cylinder(10, 25, 25, true, $fn=200);
цилиндр
Срезаем острую грани цилиндра - найдя общую часть цилиндра и сплюснутой сферы.
intersection(){
  cylinder(10, 25, 25, true, $fn=200);
  scale([2.5,2.5,1])sphere(10.5, $fn=200);
}; 
скруглили острый край заготовки
Имитируем диск колеса. С боковой поверхности вычитаем сжатую сферу.
difference(){
  intersection(){
    cylinder(10, 25, 25, true, $fn=200);
    scale([2.5,2.5,1])sphere(10.5, $fn=200);
  };
	
  translate([0, 0, 12])
  scale([2.5,2.5,1])sphere(10.5, $fn=200);
};
выемка имитирующая диск
Вырезаем ось колеса.
difference(){
  intersection(){
    cylinder(10, 25, 25, true, $fn=200);
    scale([2.5,2.5,1])sphere(10.5, $fn=200);
  };

  // боковая сферическая выемка
  translate([0, 0, 12])
  scale([2.5,2.5,1])sphere(10.5, $fn=200);

  // ось колеса
  cylinder(11, 2.5, 2.5, true, $fn=20);
};
		
отверстие для оси колеса
Имитируем спицы.
Так как спиц будет 12, чтобы не переписывать один и тот же код 12 раз применим - цикл.
Цикл for(i=[1:12]){...};. Внутри фигурных скобок - код который будет повторяться. Переменная i принимает значения от 1 до 12.
difference(){
  intersection(){
    cylinder(10, 25, 25, true, $fn=200);
    scale([2.5,2.5,1])sphere(10.5, $fn=200);
  };

  // боковая сферическая выемка
  translate([0, 0, 12])
  scale([2.5,2.5,1])sphere(10.5, $fn=200);

  // ось колеса
  cylinder(11, 2.5, 2.5, true, $fn=20);

  // спицы
  for(i=[1:12]){
    rotate([0,0,i*30])
    translate([13,0,0])
    scale([3,1,1])
  cylinder(11, 2, 2, true, $fn=50);
  };
};
вырезали спицы
Аналогично с помощью цикла, добавляем рисунок протектора.
difference(){
  intersection(){
    cylinder(10, 25, 25, true, $fn=200);
    scale([2.5,2.5,1])sphere(10.5, $fn=200);
  };

  // боковая сферическая выемка
  translate([0, 0, 12])
  scale([2.5,2.5,1])sphere(10.5, $fn=200);

  // ось колеса
  cylinder(11, 2.5, 2.5, true, $fn=20);

  // спицы
  for(i=[1:12]){
    rotate([0,0,i*30])
    translate([13,0,0])
    scale([3,1,1])
  cylinder(11, 2, 2, true, $fn=50);
  };

  // протектор
  for(i=[1:36]){
    rotate([0,0,i*10])
    translate([30,0,0])
    scale([3,1,1])
    cylinder(11, 2, 2, true, $fn=50);
  };
};
рисунок протектора на колесе

цилиндр sundarapandian kuttymovies выемка имитирующая диск отверстие для оси колеса вырезали спицы рисунок протектора на колесе

По-моему, получилось достаточно неплохо, и в то же время просто. При том, что это только начало. Если понравилось идём дальше.


OpenSCAD Урок 2. Учимся на простых примерах - функции minkowski, hull, projection. Модели плоских (2D) фигур.


На главную.



sVital
Хорошее начало. Я отдыхал читая. Так и продолжайте. Вот только выгоните с класса этих балюесов с 11Б. (маленькие они ещё такие статьи читать)

2020-02-09 04:40:49
Pedro
Колесо с нижней стороны не обрезано сферой, не симметрично получается. Нужно добавить: translate([0,0,-11]) scale([2.5,2.5,1])sphere(10,5); В фигурную скобку Difference.

2020-04-28 02:30:14
Predsedatel
Pedro, вы правы, не заметил! Надо будет поправить.

2020-05-20 08:49:14
DimsT
Автору - респект! Самый простой и толковый мануал без воды и с интересными примерами!

2020-10-28 04:15:26
Неизвестный
( im big boss ) пожалуйста

2021-02-16 02:51:59
книжный червь
в тех случаях, когда вы хотите увидеть результат работы кода в 3D: https://github.com/koendv/openscad-raspberrypi

2021-04-18 01:24:06
Неизвестный
( Владислав ) У меня есть вариант, модернизированного принципа построения многогранника в Open SCAD. Этот вариант более простой, и более эффективный. Вот как он делается: Функция faces - вообще убрана, а оставлена лишь points. При этом, программа сама понимает где у многогранника рёбра, и рисует их автоматически. Потому что, при построении многогранника, обозначаются на x,y,z координатах, лишь координаты точек, а Open SCAD, автоматически соединяет прямой линией, координату одной предыдущей обозначенной точки, с координатой одной последующей обозначенной точки (сразу следующей за этой предыдущей точкой), таким образом создавая многогранник.

2021-08-13 02:21:47

Kuttymovies !free!: Sundarapandian

in a significant negative role, which served as a turning point in his early career.

The intersection of digital technology and regional cinema has radically altered how audiences consume media. In the context of Tamil cinema (Kollywood), this evolution is deeply intertwined with the phenomenon of online piracy. A prime case study of this intersection is the search trend surrounding the 2012 hit film Sundarapandian and its association with the notorious piracy platform Kuttymovies.

The story emphasizes how situations can compel people to act against their nature, following the life and conflicts of the titular character in a rural setting.

Directed by debutant S. R. Prabhakaran and produced by its lead actor M. Sasikumar, Sundarapandian is widely considered a benchmark in Tamil cinema’s rural drama sub-genre. sundarapandian kuttymovies

These sites often contain malicious pop-up ads and "malvertising" that can infect your device with malware or trackers.

While these sites may offer free access, there are significant downsides and risks for users:

For a safe and official viewing experience, you can stream Sundarapandian on several legal platforms. Official Streaming Platforms : Watch the full movie in HD with Sun NXT . Amazon Prime Video : Available for streaming or rental. in a significant negative role, which served as

Kuttymovies is a notorious piracy website known for distributing Indian films, including Tamil, Telugu, Malayalam, and Hindi titles. It often hosts "Kutty Movies" versions of popular films like Sundarapandian, allowing users to download content in various formats and file sizes. The Rise of Rural Dramas in Tamil Cinema

While piracy sites offer "free" access to content, users pay an hidden cost regarding digital security and data privacy. Navigating networks like Kuttymovies exposes devices to severe vulnerabilities:

Kutty's breakthrough film, "Iruvar," released in 2004, starred Ajith Kumar and won critical acclaim. The film's success can be attributed to Kutty's innovative storytelling and his ability to balance action, drama, and romance. "Iruvar" cemented Kutty's position as a talented filmmaker in Tamil cinema. A prime case study of this intersection is

The film industry supports thousands of daily-wage workers (lightmen, caterers, set designers); lower industry profits directly threaten their livelihoods. Risks to the End User

Remember: supporting legal content is not just a choice—it is a responsibility we all share in preserving the art and livelihood of the film industry.

: The plot centers on Sundarapandian helping a friend woo a girl, only for a complex love triangle to emerge when she reveals her long-standing feelings for Sundarapandian himself.

Sundar C's contribution to Tamil cinema cannot be overstated. He has been instrumental in launching the careers of several actors and actresses, providing them with a platform to showcase their talents. His films often tackle social issues with humor and sensitivity, making cinema accessible and engaging for a broad audience.

: The film starts as a familiar rural romance where Sundarapandian (Sasikumar) tries to help his friend woo Archana (Lakshmi Menon), only for her to reveal she has long been in love with Sundarapandian himself. However, the second half transitions into a gritty drama involving betrayal and deep-seated grudges.

Неизвестный
( Владислав ) Владислав ) У меня есть вариант, модернизированного принципа построения многогранника в Open SCAD. Этот вариант более простой, и более эффективный. Вот как он делается: Функция faces - вообще убрана, а оставлена лишь points. При этом, программа сама понимает где у многогранника рёбра, и рисует их автоматически. Потому что, при построении многогранника, обозначаются на x,y,z координатах, лишь координаты точек, а Open SCAD, автоматически соединяет прямой линией, координату одной предыдущей обозначенной точки, с координатой одной последующей обозначенной точки (сразу следующей за этой предыдущей точкой), таким образом создавая многогранник.., в котором эти линии - его грани. При этом, можно обозначать координату каждой новой такой точки в любом направлении относительно места расположения предыдущей ей точки, и обозначать при этом новые точки на местах уже обозначенных ранее точек, таким образом, иногда даже создавать этим повторно и уже ранее созданные грани этого многогранника (которые естественно не обозначаются на чертеже создаваемого объекта как новые линии, раз они уже изображены), и Open SCAD не считает это ошибкой, так как это новое правило этой программы.

2021-11-15 06:41:27
SANS
Очень удобная и простая программа 3D-моделирвания!

2022-02-25 02:48:09
dickname228
difference(){ intersection(){ cylinder(10, 25, 25, true, $fn=200); scale([2.5,2.5,1])sphere(10.5, $fn=200); }; // боковая сферическая выемка translate([0, 0, 12]) scale([2.5,2.5,1])sphere(10.5, $fn=200); // ось колеса cylinder(11, 2.5, 2.5, true, $fn=20); // спицы for(i=[1:12]){ rotate([0,0,i*30]) translate([13,0,0]) scale([3,1,1]) cylinder(11, 2, 2, true, $fn=50); }; // протектор for(i=[1:36]){ rotate([0,0,i*10]) translate([30,0,0]) scale([3,1,1]) cylinder(11, 2, 2, true, $fn=50); }; };

2022-11-17 09:10:08
fetiso4ka
всем привет с урока робототехники!!!

2023-01-18 12:22:59
Irga
Всем удачи на ЕГЭ!1!!! :D

2023-01-18 12:24:58
fetiso4ka
всем привет с урока робототехники!!!

2023-01-18 12:25:09
Irga
Всем удачи на ЕГЭ!1!!! :D

2023-01-18 12:25:22
Irga
Всем удачи на ЕГЭ!1!!! :D

2023-01-18 12:26:14
Irga
Всем удачи на ЕГЭ!1!!! :D

2023-01-18 12:26:21
Irga
Всем удачи на ЕГЭ!1!!! :D

2023-01-18 12:26:40