<problem display_name="Drag and drop demos: drag and drop icons or labels to proper positions." > <customresponse> <text> <h4>[Draggable is reusable example]</h4> <br/> <h4>Please label all hydrogen atoms.</h4> <br/> </text> <drag_and_drop_input img="/static/images/images_list/ethglycol.jpg" target_outline="true" one_per_target="true" no_labels="true" label_bg_color="rgb(222, 139, 238)" > <draggable id="1" label="Hydrogen" can_reuse='true' /> <target id="t1_o" x="10" y="67" w="100" h="100" /> <target id="t2" x="133" y="3" w="70" h="70" /> <target id="t3" x="2" y="384" w="70" h="70" /> <target id="t4" x="95" y="386" w="70" h="70" /> <target id="t5_c" x="94" y="293" w="91" h="91" /> <target id="t6_c" x="328" y="294" w="91" h="91" /> <target id="t7" x="393" y="463" w="70" h="70" /> <target id="t8" x="344" y="214" w="70" h="70" /> <target id="t9_o" x="445" y="162" w="100" h="100" /> <target id="t10" x="591" y="132" w="70" h="70" /> </drag_and_drop_input> <answer type="loncapa/python"> <![CDATA[ correct_answer = [{ 'draggables': ['1'], 'targets': ['t2', 't3', 't4', 't7', 't8', 't10'], 'rule': 'exact' }] if draganddrop.grade(submission[0], correct_answer): correct = ['correct'] else: correct = ['incorrect'] ]]> </answer> </customresponse> <customresponse> <text> <h4>[Complex grading example]</h4><br/> <h4>Describe carbon molecule in LCAO-MO.</h4> <br/> </text> <drag_and_drop_input img="/static/images/images_list/lcao-mo/lcao-mo.jpg" target_outline="true" > <!-- filled bond --> <draggable id="1" icon="/static/images/images_list/lcao-mo/u_d.png" can_reuse="true" /> <!-- up bond --> <draggable id="7" icon="/static/images/images_list/lcao-mo/up.png" can_reuse="true" /> <!-- sigma --> <draggable id="11" icon="/static/images/images_list/lcao-mo/sigma.png" can_reuse="true" /> <!-- sigma* --> <draggable id="13" icon="/static/images/images_list/lcao-mo/sigma_s.png" can_reuse="true" /> <!-- pi --> <draggable id="15" icon="/static/images/images_list/lcao-mo/pi.png" can_reuse="true" /> <!-- pi* --> <draggable id="16" icon="/static/images/images_list/lcao-mo/pi_s.png" can_reuse="true" /> <!-- images that should not be dragged --> <draggable id="17" icon="/static/images/images_list/lcao-mo/d.png" can_reuse="true" /> <!-- positions of electrons and electron pairs --> <target id="s_left" x="130" y="360" w="32" h="32"/> <target id="s_right" x="505" y="360" w="32" h="32"/> <target id="s_sigma" x="320" y="425" w="32" h="32"/> <target id="s_sigma_star" x="320" y="290" w="32" h="32"/> <target id="p_left_1" x="80" y="100" w="32" h="32"/> <target id="p_left_2" x="125" y="100" w="32" h="32"/> <target id="p_left_3" x="175" y="100" w="32" h="32"/> <target id="p_right_1" x="465" y="100" w="32" h="32"/> <target id="p_right_2" x="515" y="100" w="32" h="32"/> <target id="p_right_3" x="560" y="100" w="32" h="32"/> <target id="p_pi_1" x="290" y="220" w="32" h="32"/> <target id="p_pi_2" x="335" y="220" w="32" h="32"/> <target id="p_sigma" x="315" y="170" w="32" h="32"/> <target id="p_pi_star_1" x="290" y="40" w="32" h="32"/> <target id="p_pi_star_2" x="340" y="40" w="32" h="32"/> <target id="p_sigma_star" x="315" y="0" w="32" h="32"/> <!-- positions of names of energy levels --> <target id="s_sigma_name" x="400" y="425" w="32" h="32"/> <target id="s_sigma_star_name" x="400" y="290" w="32" h="32"/> <target id="p_pi_name" x="400" y="220" w="32" h="32"/> <target id="p_sigma_name" x="400" y="170" w="32" h="32"/> <target id="p_pi_star_name" x="400" y="40" w="32" h="32"/> <target id="p_sigma_star_name" x="400" y="0" w="32" h="32"/> </drag_and_drop_input> <answer type="loncapa/python"><![CDATA[ correct_answer = [ { 'draggables': ['1'], 'targets': [ 's_left', 's_right', 's_sigma', 's_sigma_star', 'p_pi_1', 'p_pi_2' ], 'rule': 'exact' }, { 'draggables': ['7'], 'targets': ['p_left_1', 'p_left_2', 'p_right_1','p_right_2'], 'rule': 'exact' }, { 'draggables': ['11'], 'targets': ['s_sigma_name', 'p_sigma_name'], 'rule': 'exact' }, { 'draggables': ['13'], 'targets': ['s_sigma_star_name', 'p_sigma_star_name'], 'rule': 'exact' }, { 'draggables': ['15'], 'targets': ['p_pi_name'], 'rule': 'exact' }, { 'draggables': ['16'], 'targets': ['p_pi_star_name'], 'rule': 'exact' }] if draganddrop.grade(submission[0], correct_answer): correct = ['correct'] else: correct = ['incorrect'] ]]></answer> </customresponse> <customresponse> <text> <h4>[Many draggables per target]</h4><br/> <h4>Move two Stars and three Ants to most left target and one Label3 and four Label2 to most right target.</h4><br/> </text> <drag_and_drop_input img="/static/images/cow.png" target_outline="true" one_per_target="false"> <draggable id="1" label="Label 1" can_reuse="true" /> <draggable id="name_with_icon" label="Ant" icon="/static/images/images_list/ant.jpg" can_reuse="true" /> <draggable id="with_icon" label="Cloud" icon="/static/images/images_list/cloud.jpg" can_reuse="true" /> <draggable id="5" label="Label2" can_reuse="true" /> <draggable id="2" label="Drop" icon="/static/images/images_list/drop.jpg" can_reuse="true" /> <draggable id="name_label_icon3" label="Grass" icon="/static/images/images_list/grass.jpg" can_reuse="true" /> <draggable id="name4" label="Star" icon="/static/images/images_list/star.png" can_reuse="true" /> <draggable id="7" label="Label3" can_reuse="true" /> <target id="t1" x="20" y="20" w="90" h="90"/> <target id="t2" x="300" y="100" w="90" h="90"/> <target id="t3" x="150" y="40" w="50" h="50"/> </drag_and_drop_input> <answer type="loncapa/python"><![CDATA[ correct_answer = [ { 'draggables': ['name4'], 'targets': [ 't1', 't1' ], 'rule': 'exact' }, { 'draggables': ['name_with_icon'], 'targets': [ 't1', 't1', 't1' ], 'rule': 'exact' }, { 'draggables': ['5'], 'targets': [ 't2', 't2', 't2', 't2' ], 'rule': 'exact' }, { 'draggables': ['7'], 'targets': [ 't2' ], 'rule': 'exact' } ] if draganddrop.grade(submission[0], correct_answer): correct = ['correct'] else: correct = ['incorrect'] ]]></answer> </customresponse> <customresponse> <text> <h4>[Draggables can be placed anywhere on base image]</h4><br/> <h4> Place -Grass- in the middle of the image and -Ant- in the right upper corner.</h4><br/> </text> <drag_and_drop_input img="/static/images/cow.png" > <draggable id="1" label="Label 1" can_reuse="true" /> <draggable id="ant" label="Ant" icon="/static/images/images_list/ant.jpg" can_reuse="true" /> <draggable id="with_icon" label="Cloud" icon="/static/images/images_list/cloud.jpg" can_reuse="true" /> <draggable id="5" label="Label2" can_reuse="true" /> <draggable id="2" label="Drop" icon="/static/images/images_list/drop.jpg" can_reuse="true" /> <draggable id="grass" label="Grass" icon="/static/images/images_list/grass.jpg" can_reuse="true" /> <draggable id="name4" label="Star" icon="/static/images/images_list/star.png" can_reuse="true" /> <draggable id="7" label="Label3" can_reuse="true" /> </drag_and_drop_input> <answer type="loncapa/python"><![CDATA[ correct_answer = { 'grass': [[300, 200], 200], 'ant': [[500, 0], 200] } if draganddrop.grade(submission[0], correct_answer): correct = ['correct'] else: correct = ['incorrect'] ]]></answer> </customresponse> <customresponse> <text> <h4>[Another anyof example]</h4><br/> <h4>Please identify the Carbon and Oxygen atoms in the molecule.</h4><br/> </text> <drag_and_drop_input img="/static/images/images_list/ethglycol.jpg" target_outline="true" one_per_target="true"> <draggable id="l1_c" label="Carbon" can_reuse="true" /> <draggable id="l2" label="Methane" can_reuse="true" /> <draggable id="l3_o" label="Oxygen" can_reuse="true" /> <draggable id="l4" label="Calcium" can_reuse="true" /> <draggable id="l7" label="Hydrogen" can_reuse="true" /> <target id="t1_o" x="10" y="67" w="100" h="100"/> <target id="t2" x="133" y="3" w="70" h="70"/> <target id="t3" x="2" y="384" w="70" h="70"/> <target id="t4" x="95" y="386" w="70" h="70"/> <target id="t5_c" x="94" y="293" w="91" h="91"/> <target id="t6_c" x="328" y="294" w="91" h="91"/> <target id="t7" x="393" y="463" w="70" h="70"/> <target id="t8" x="344" y="214" w="70" h="70"/> <target id="t9_o" x="445" y="162" w="100" h="100"/> <target id="t10" x="591" y="132" w="70" h="70"/> </drag_and_drop_input> <answer type="loncapa/python"><![CDATA[ correct_answer = [ { 'draggables': ['l3_o'], 'targets': ['t1_o', 't9_o'], 'rule': 'exact' }, { 'draggables': ['l1_c'], 'targets': ['t5_c', 't6_c'], 'rule': 'exact' } ] if draganddrop.grade(submission[0], correct_answer): correct = ['correct'] else: correct = ['incorrect'] ]]></answer> </customresponse> <customresponse> <text> <h4>[Exact number of draggables for a set of targets.]</h4><br/> <h4>Drag two Grass and one Star to first or second positions, and three Cloud to any of the three positions.</h4> <br/> </text> <drag_and_drop_input img="/static/images/cow.png" target_outline="true" one_per_target="false"> <draggable id="1" label="Label 1" can_reuse="true" /> <draggable id="name_with_icon" label="Ant" icon="/static/images/images_list/ant.jpg" can_reuse="true" /> <draggable id="with_icon" label="Cloud" icon="/static/images/images_list/cloud.jpg" can_reuse="true" /> <draggable id="5" label="Label2" can_reuse="true" /> <draggable id="2" label="Drop" icon="/static/images/images_list/drop.jpg" can_reuse="true" /> <draggable id="name_label_icon3" label="Grass" icon="/static/images/images_list/grass.jpg" can_reuse="true" /> <draggable id="name4" label="Star" icon="/static/images/images_list/star.png" can_reuse="true" /> <draggable id="7" label="Label3" can_reuse="true" /> <target id="t1" x="20" y="20" w="90" h="90"/> <target id="t2" x="300" y="100" w="90" h="90"/> <target id="t3" x="150" y="40" w="50" h="50"/> </drag_and_drop_input> <answer type="loncapa/python"><![CDATA[ correct_answer = [ { 'draggables': ['name_label_icon3', 'name_label_icon3'], 'targets': ['t1', 't3'], 'rule': 'unordered_equal+number' }, { 'draggables': ['name4'], 'targets': ['t1', 't3'], 'rule': 'anyof+number' }, { 'draggables': ['with_icon', 'with_icon', 'with_icon'], 'targets': ['t1', 't2', 't3'], 'rule': 'anyof+number' } ] if draganddrop.grade(submission[0], correct_answer): correct = ['correct'] else: correct = ['incorrect'] ]]></answer> </customresponse> <customresponse> <text> <h4>[As many as you like draggables for a set of targets.]</h4><br/> <h4>Drag some Grass to any of the targets, and some Stars to either first or last target.</h4> <br/> </text> <drag_and_drop_input img="/static/images/cow.png" target_outline="true" one_per_target="false"> <draggable id="1" label="Label 1" can_reuse="true" /> <draggable id="name_with_icon" label="Ant" icon="/static/images/images_list/ant.jpg" can_reuse="true" /> <draggable id="with_icon" label="Cloud" icon="/static/images/images_list/cloud.jpg" can_reuse="true" /> <draggable id="5" label="Label2" can_reuse="true" /> <draggable id="2" label="Drop" icon="/static/images/images_list/drop.jpg" can_reuse="true" /> <draggable id="name_label_icon3" label="Grass" icon="/static/images/images_list/grass.jpg" can_reuse="true" /> <draggable id="name4" label="Star" icon="/static/images/images_list/star.png" can_reuse="true" /> <draggable id="7" label="Label3" can_reuse="true" /> <target id="t1" x="20" y="20" w="90" h="90"/> <target id="t2" x="300" y="100" w="90" h="90"/> <target id="t3" x="150" y="40" w="50" h="50"/> </drag_and_drop_input> <answer type="loncapa/python"><![CDATA[ correct_answer = [ { 'draggables': ['name_label_icon3'], 'targets': ['t1', 't2', 't3'], 'rule': 'anyof' }, { 'draggables': ['name4'], 'targets': ['t1', 't2'], 'rule': 'anyof' } ] if draganddrop.grade(submission[0], correct_answer): correct = ['correct'] else: correct = ['incorrect'] ]]></answer> </customresponse> </problem>